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出 . 版 X . 明 


信息 技术 是 当今 世界 社会 经 济 发 展 的 重要 驱动 力 ,网 络 技 术 对 信息 社会 发 展 的 重要 性 
更 是 不 言 而 喻 。 随 着 互联 网 技术 的 普及 和 推广 ,人 们 日 常 学 习 和 工作 越 来 越 依赖 于 网 络 。 
目前 ,各 行 各 业 都 处 在 全 面 网 络 化 和 信息 化 建设 进程 中 ,对 网 络 技能 型 人 才 的 需求 也 与 日 俱 
增 , 计 算 机 网 络 行 业已 成 为 技术 人 才 稀 缺 的 行业 之 一 。 为 了 培养 适应 现代 信息 技术 发 展 的 
网 络 技能 型 人 才 ,高 职高 专 院 校 网 络 技术 及 相关 专业 的 课程 建设 与 改革 就 显得 尤为 重要 。 

近年 来 ,众多 高 职高 专 院 校对 人 才 培 养 模式 .专业 建设 课程 建设 .师资 建设 、 实 训 基 地 
建设 等 进行 了 大 量 的 改革 与 探索 ,以 适应 社会 对 高 技能 人 才 的 培养 要 求 。 在 网 络 专业 建设 
中 ,从 网 络 工程 .网 络 管理 岗位 需求 出 发 进行 课程 规划 和 建设 ,是 网 络 技能 型 人 才 培 养 的 必 
由 之 路 。 基 于 此 ,我 们 组 织 高 校 教育 教学 专家 、 专 业 负 责 人 、 骨 和 干 教师 、 企 业 管 理 人 员 和 工程 
技术 人 员 对 相应 的 职业 岗位 进行 了 调研 、. 剖 析 , 并 成 立 教材 编写 委员 会 ,对 课程 体系 进行 重 
新 规划 ,编写 了 本 系列 教程 。 

本 系列 教程 的 编写 委员 会 成 员 由 从 事 高 职高 专 教育 的 专家 ,高 职 院 校 主管 教学 的 院 长 、 
系 主任 .教研室 主任 等 组 成 ,主要 编撰 者 都 是 院 校 网 络 专业 负责 人 或 相应 企业 的 资深 工 
程 师 。 

本 系列 教程 采用 项 目 导 向 、 任 务 驱动 的 教学 方法 ,以 培养 学 生 的 岗位 能 力 为 着 眼 点 , 面 
向 岗位 设计 教学 项 目 , 融 教学、 做 为 一 体 ,力争 做 到 学 得 会 .用 得 上 。 在 讲授 专业 技能 和 知 
识 的 同时 ,也 注重 学 生 职 业 素养 .科学 思维 方式 与 创新 能 力 的 培养 ,并 体现 新 技术 、 新 工艺 、 
新 标准 。 本 系列 教程 对 应 的 岗位 能 力 包括 计算 机 及 网 络 设备 营销 能 力 、 计 算 机 设备 的 组 装 
与 维护 能 力 、 网 页 设计 能 力 、 综 合 布线 设计 与 施工 能 力 、 网 络 工 程 实施 能 力 、 网 站 策划 与 开发 
能 力 、 网 络 安 全 管理 能 力 及 网 络 系统 集成 能 力 等 。 

为 了 满足 教师 教学 的 需要 ,我 们 免费 提供 教学 课件 、 习 题解 答 、 素 材 库 等 ,以 及 其 他 辅助 
教学 的 资料 。 

后 续 , 我 们 会 密切 关注 网 络 技术 和 教学 的 发 展 趋势 ,以 及 社会 就 业 岗 位 的 新 需求 和 变 
化 ,及 时 对 系列 教程 进行 完善 和 补充 ,吸纳 新 模式 、 适 用 的 课程 教材 。 同 时 ,非常 欢迎 专家 、 
教师 对 本 系列 教程 提出 宝贵 意见 ,也 非常 欢迎 专家 、 教 师 积 极 参与 我 们 的 教材 建设 , 群 策 群 
力 ,为 我 国 高 等 职业 教育 提供 优秀 的 \ 有 鲜明 特色 的 教材 。 


高 职高 专 网 络 技术 专业 岗位 能 力 构 建 系列 教程 编写 委员 会 
清华 大 学 出 版 社 
2o11 年 4 月 


oreword 人 前， D 


ASP. NET 2. 0 是 一 种 基于 服务 器 的 功能 强大 的 技术 ,用 于 为 Internet 或 企业 的 内 部 
网 (Intranet) 创 建 动态 的 .交互 式 的 HTML 网 页 。ASP. NET 2.0 构建 在 . NET Framework 
2.0 之 上 ,扩展 了 ASP. NET 1.0 f ASP. NET 1.1 的 功能 ,其 内 核 是 一 个 基于 控件 的 、 事 件 
了 驱动 的 架构 ,这 意味 着 只 需要 向 页 面 中 添加 少量 的 代码 ,就 可 以 完成 强大 的 功能 。 

本 书 以 C# 为 编程 语言 ,结合 作者 多 年 的 项 目 开 发 经 验 以 及 丰富 的 教学 经 验 ,详细 介绍 
ASP. NET 2.0 的 基础 知识 、 特 点 和 具体 的 应 用 。 全 书 共 分 为 9 章 ,内 容 包 括 ASP. NET f 
述 、C# 语 言 基础 .服务 器 控件 .ASP. NET 内 置 对 象 .ASP. NET 数据 库 编程 .数据 控 件 、 文 
件 处 理 技 术 、ASP. NET 配置 和 优化 、 网 上 书店 开发 实例 。 

第 1 章 讲解 ASP. NET 的 基础 知识 。 首 先 对 ASP. NET 技术 进行 概括 介绍 ,然后 介绍 
如 何 配置 ASP.NET 的 运行 环境 ,最 后 通过 一 个 实例 介绍 如 何 创建 ASP.NET 应 用 程序 。 

第 2 章 讲解 C# 编程 语言 。 首 先 讲解 C# 的 数据 类 型 和 变量 ,然后 讲解 流程 控制 的 相 
关 知 识 , 最 后 讲解 类 和 对 象 。 

第 3 章 讲解 ASP. NET 服务 器 控件 。 首 先 介 绍 ASP. NET 文件 的 构成 和 ASP. NET 
页 面 的 执行 过 程 ,然后 详细 介绍 HTML 42 fF, Web 控件 、 验 证 控件 。 

第 4 章 讲解 ASP.NET 内 置 对 象 。 主 要 包括 Page 31 & , Response 31 & , Request 对 象 、 
Application 3f & „Session 对 象 以 及 Server 对 象 。 

第 5 章 讲解 ASP. NET 数据 库 编程 。 首 先 概括 介绍 ADO. NET, 然 后 介绍 如 何 连接 数 
据 库 ,如 何 使 用 DataReader 对 象 读 取 数 据 库 , 最 后 介绍 如 何 使 用 DataSet 对 象 访问 数据 库 。 
第 6 章 讲解 数据 控件 。 重 点 介绍 DataGrid 控件 ,DataList 控件 和 Repeater 控件 。 

第 7 章 讲解 文件 处 理 技术 。 首 先 介绍 Directory 类 、File 类 的 常用 方法 ,然后 介绍 如 何 
使 用 StreamReader 与 StreamWriter 类 读 写 文本 文件 ,如 何 使 用 FileStream 类 读 写 文本 
pe 

第 8 章 讲解 ASP. NET 配置 和 优化 。 首 先 介 绍 Web. config, Global. asax 两 大 配置 文 
件 , 然 后 介绍 主题 和 皮肤 ,最 后 介绍 母 版 页 。 

第 9 章 通过 开发 一 个 网 上 书店 系统 演示 如 何 使 用 多 种 技术 来 开发 Web 网 站 。 本 章 除 
了 介绍 ASP. NET 的 具体 技术 之 外 ,对 于 需求 分 析 和 系统 设计 、 数 据 库 设 计 以 及 功能 模块 
的 划分 也 有 比较 详细 的 介绍 ,有 利于 读者 了 解 一 个 实际 项 目的 开发 流程 。 

本 书 内 容 的 讲解 由 浅 入 深 , 循 序 渐进 ,通俗 易 懂 ,适合 自学 ,力求 具有 实用 性 、 可 操作 性 。 
书 中 对 每 个 知识 点 都 有 实例 演示 ,有 助 于 读者 理解 概念 .巩固 知识 .掌握 要 点 、 攻 克 难 点 。 在 
每 章 后 精心 设计 了 2 一 4 道 较 为 实用 的 实 训 题 , 进 一 步 检验 学 生 对 各 个 知识 点 的 综合 应 用 
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能 力 。 

本 书 可 作为 高 职 院 校 ,独立 学 院 信息 工 程 类 专业 的 教学 用 书 , 也 可 作为 ASP. NET 网 
站 开发 人 员 的 自学 参考 书 和 相关 培训 班 的 教学 用 书 。 

本 书 由 陈 明 忠 、 江 永 池 担 任 主 编 , 张 居 武 、 阳 娣 兰 担任 副 主编 , 陈 郁 清 、 王 霞 、 陈 明 波 参 加 
了 编写 。 全 书 由 陈 明 忠 副教授 统 阅 定稿 。 本 书 在 编写 和 出 版 过 程 中 得 到 了 汕头 职业 技术 学 
院 、 湖 南 工业 大 学 科技 学 院 等 的 大 力 支持 , 谨 此 鸣谢 。 

由 于 作者 水 平 所 限 , 书 中 如 有 不 足 之 处 敬 请 广大 读者 批评 指正 ,以 便 修订 时 改进 。 如 读 
者 在 使 用 本 书 的 过 程 中 有 其 他 意见 或 建议 ,也 请 不 吝 赐教 。 


编 者 
2011 年 4 月 
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ASP.NET 是 Microsoft 推出 的 基于 通用 语言 的 编程 框架 ,可 以 用 来 在 服务 器 端 构 建功 
能 强大 的 Web 应 用 程序 ,从 而 为 人 们 提供 了 一 种 办 新 的 网 络 编程 模型 。 本 章 首先 对 ASP 
.NET 进行 概括 的 介绍 ,然后 给 出 ASP. NET 的 运行 环境 ,最 后 给 出 创建 一 个 简单 ASP 
.NET 应 用 程序 的 方法 。 


ERES 


。 了解.NET 的 基本 结构 

* 了解 什么 是 ASP. NET 

* 掌握 TIS 的 配置 方法 

。 掌握 创建 虚拟 目录 的 方法 

。 掌握 创建 ASP. NET 应 用 程序 的 步骤 


1.1 ASP. NET 简介 


ASP. NET 是 Microsoft 公司 于 2000 年 推出 的 一 种 Internet 编程 技术 , 是 . NET 
Framework 的 组 成 部 分 ,可 用 于 在 服务 器 上 生成 功能 强大 的 Web 应 用 程序 。 


1.1.1 .NET 简介 


.NET 是 Microsoft 公司 发 布 的 新 一 代 系 统 、 服 务 和 编程 平台 ,主要 由 . NET 
Framework 和 Microsoft Visual Studio. NET 集成 开发 环境 组 成 。 


.NET Framework 

. NET Framework 是 一 种 新 的 计算 平台 , 它 包 含 了 在 操作 系统 上 进行 软件 开发 需要 的 
所 有 层 , 简 化 了 在 高 度 分 布 式 Internet 环境 中 的 应 用 程序 开发 。. NET Framework 主要 包括 
两 个 最 基本 的 内 核 , 即 公共 语言 运行 库 (Common Language Runtime, CLR) 和 . NET 
Framework 基本 类 库 (Base Class Library, BCL) ,它们 为 .NET 平台 的 实现 提供 了 底层 技术 
支持 。 

公共 语言 运行 库 是 . NET Framework 的 基础 ,也 是 . NET Framework 运行 时 的 环境 ， 
它 是 运行 时 代码 的 管理 者 ,提供 核心 服务 。 它 的 主要 功能 是 把 . NET 语言 编译 成 与 机 器 无 
关 的 中 间 语 言 MSIL(Microsoft Intermediate Language) ,在 执行 代码 时 使 用 即时 编译 器 JIT 
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(Just In Time) 将 MSIL 翻译 成 面向 机 器 的 二 进 制 编码 。 

.NET Framework 基本 类 库 是 一 个 综合 性 的 面向 对 象 的 可 重用 类 型 的 集合 , 例如 
ADO. NET、ASP. NET 等 。BCL 位 于 公共 语言 运行 库 的 上 层 ,与 .NET Framework 紧密 集 
成 在 一 起 ,可 被 . NET 支持 的 任何 语言 使 用 ,这 就 是 在 ASP. NET 中 可 以 使 用 C# , Visual 
Basic. NET, Visual C++ . NET 等 语言 进行 软件 开发 的 原因 。BCL 的 组 织 是 以 命名 空间 为 
基础 的 ,最 顶层 的 命名 空间 是 System。 


2. Visual Studio .NET 集成 开发 环境 

Visual Studio .NET 是 为 . NET Framework 应 用 而 设置 的 集成 开发 环境 (Integrated 
Development Environment, IDE) , 它 在 . NET Framework 和 公共 语言 规范 CLS( Common 
Language Specification) 基 础 上 可 运行 Visual Basic. NET, C+ .C# 、J# 等 多 种 语言 。 

公共 语言 规范 CLS 定义 了 各 种 语言 必须 遵守 的 公共 标准 , 它 是 一 组 可 以 以 编程 方式 验 
证 的 规则 ,是 大 多 数 语 言 共 有 的 功能 的 集合 。 


1.3.2. 动态 网 页 设计 技术 


Web 页 按 其 表现 形式 可 分 为 静态 网 页 和 动态 网 页 两 种 。 所 谓 静态 网 页 是 指 该 网 页 文 
件 里 只 有 HTML 标签 ,没有 其 他 可 执行 程序 。 页 面 一 经 制作 完成 ,其 内 容 就 不 会 再 变化 ， 
不 管 谁 打开 ,什么 时 间 打开 ,其 内 容 都 是 一 样 的 。 

动态 网 页 是 指 “ 具 有 交互 性 的 页 面 ", 即 在 网 页 源 代码 不 变 的 情况 下 ,网 页 的 内 容 可 根据 
访问 者 ,访问 时 间或 者 访问 目的 的 不 同 而 显示 不 同 的 内 容 ,如 BBS ,留言 析 和 聊天 室 等 。 动 
态 网 页 的 扩展 名 一 般 为 . asp.. jsp. php、. aspx。 

目前 比较 流行 的 动态 网 页 设计 技术 主要 有 以 下 几 种 。 

(1) ASP。ASP 即 Active Server Page, 是 一 种 Web 服务 器 端的 开发 技术 ,利用 它 可 以 
编写 和 执行 动态 的 ,互动 的 、 高 性 能 的 Web 应 用 程序 。ASP 采用 VBScript 和 JavaScript 作 
为 脚本 语言 。 

(2) JSP, JSP Hl Java Server Page, 它 是 由 Sun 公司 于 1999 年 6 月 推出 的 新 技术 ,是 基 
于 Java Servlet 以 及 整个 Java 体系 的 Web 开发 技术 。 由 于 JSP 采用 Java 作为 脚本 语言 ， 
有 极 强 的 扩展 性 、 良 好 的 收缩 性 ,以 及 与 平台 无 关 的 开发 特性 ,被 认为 是 极 具 发 展 潜力 的 动 
态 网 站 技术 。 

(3) PHP, PHP 即 Hypertext Processor( 超 文本 处 理 器 ) ,是 一 种 跨 平台 的 服务 器 端 脚 
本 语言 。 它 大 量 借用 C Java 和 Perl 语言 的 语法 ,并 耦合 PHP 自己 的 特性 ,使 Web 开发 者 
能 够 快速 地 写 出 动态 生成 页 面 。 它 支持 目前 绝 大 多 数 数据 库 。 还 有 一 点 ,PHP 是 完全 免费 
的 ,可 以 从 PHP 官方 站 点 (http://www. php. net) 自 由 下 载 ,而 且 可 以 不 受 限 制 地 获得 源 
码 , 甚 至 可 以 向 其 中 加 入 自己 需要 的 特色 。 

(4) ASP. NET。 在 ASP 的 基础 上 ,微软 公司 推出 了 ASP. NET, 但 它 不 是 ASP 的 简单 
升级 , 它 不 仅 吸收 了 ASP 技术 的 优点 并 弥补 了 ASP 的 某 些 缺憾 ,更 重要 的 是 , 它 借 鉴 了 
Java, Visual Basic 语言 的 开发 优势 ,从 而 成 为 Microsoft 推出 的 新 一 代 动 态 服务 器 页 面 技 
术 。ASP. NET 是 微软 开发 的 新 的 体系 结构 . NET 的 一 部 分 ,其 全 新 的 技术 架构 会 使 每 个 
人 的 编程 工作 变 得 更 简单 。 
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1.1.3 ASP. NET 的 优势 


ASP. NET 是 微软 推出 的 基于 通用 语言 的 编程 框架 ,使 用 它 可 以 在 服务 器 端 创建 强大 
的 Web 应 用 程序 ,例如 ,商务 网 站 、 聊 天 室 ,论坛 等 , 它 是 新 一 代 编制 企业 Web 应 用 程序 的 
平台 ,为 开发 人 员 提供 了 一 个 崭新 的 Web 编程 模型 。 

首先 ,ASP. NET 是 基于 . NET 平台 的 ,开发 者 可 以 使 用 与 . NET 兼容 的 语言 ,所 有 
.NET Framework 技术 在 ASP. NET 中 都 是 可 用 的 。 

其 次 ,ASP. NET 在 技术 设计 过 程 中 充分 考虑 到 程序 的 开发 效率 问题 ,可 以 使 用 所 见 即 
所 得 的 HTML 编辑 器 或 其 他 的 编程 工具 来 开发 ASP. NET 程序 ,包括 Visual Studio. NET 
版 本 。 可 将 设计 、 开 发 .编译 和 运行 集中 在 一 起 ,以 便 极 大 地 提高 ASP. NET 程序 的 开发 
效率 。 

ASP. NET 的 技术 优势 主要 体现 在 以 下 几 个 方面 。 

COD) 更 好 的 性 能 。ASP. NET 代码 不 再 是 解释 型 的 脚本 ,而 是 运行 于 服务 器 端 经 过 编 
译 的 代码 ,同时 由 于 引进 了 早期 绑 定 ,本 地 优化 、 缓 存 服务 等 技术 ,大 大 提高 了 ASP.NET 
的 执行 效率 。 

(2) 更 好 的 语言 特性 。 当 前 ASP. NET 支持 完全 面向 对 象 的 Visual Basic, C # 和 
JScript 语言 ,意味 着 开发 者 不 仅 可 以 利用 这 些 语言 来 开发 ASP. NET 程序 ,而且 可 以 利用 
这 些 语 言 所 具有 的 优点 ,包括 这 些 开发 语言 的 类 库 、 消 息 处 理 模型 等 。 此 外 ,ASP.NET 是 
完全 基于 组 件 的 ,所 有 的 页 面 .COM 对 象 乃 至 HTML 元 素 都 可 以 视 为 对 象 。 

G) 更 加 易于 开发 。ASP. NET 提供 了 很 多 基于 常用 功能 的 控件 ,使 诸如 表单 提交 、 表 
单 验证 ,数据 交互 等 常用 操作 变 得 更 加 简单 。 同 时 ,通过 引入 “代码 隐藏 技术 ,将 用 户 界 面 
和 实现 逻辑 分 离 ,使 程序 更 易于 维护 。 

(4) 更 强大 的 IDE 支持 。 微 软 为 . NET 的 开发 者 准备 了 Visual Studio 的 . NET 版 
本 (简称 VS. NET), VS. NET 提供 了 强大 、 高 效 的 . NET 程序 的 集成 开发 环境 ,支持 
所 见 即 所 得 、 控 件 拖 放 、 编 译 调试 等 功能 ,使 开发 ASP. NET 程序 变 得 更 加 快速 和 
方便 。 

(5) 更 易于 配置 管理 。ASP. NET 程序 的 所 有 配置 都 存储 在 基于 XML 的 文件 中 ， 
对 这 些 文 件 进行 编辑 即 可 完成 配置 ,这 将 大 大 简化 对 服务 器 端 环境 和 Web 程序 的 配置 

(6) 更 易于 扩展 。ASP.NET 良好 的 结构 使 程序 扩展 更 加 简单 ,开发 者 可 以 方便 地 开 
发 自己 的 控件 来 扩充 ASP. NET 的 功能 。 

(7) 更 加 安全 。ASP. NET 具有 良好 的 结构 ,能够 确保 程序 的 安全 性 。ASP. NET 提供 
了 多 种 认证 授权 的 安全 机 制 ,使 开发 人 员 更 容易 管理 站 点 的 资源 。 


1.1.4 ASP. NET 与 ASP 的 对 比 


虽然 ASP.NET 向 前 兼容 ASP, 用 户 以 前 编写 的 ASP 脚本 几乎 不 做 任何 修改 就 可 以 
运行 在 .NET 平 台 上 ,但 是 ASP.NET 与 ASP 技术 还 是 具有 一 定 差别 的 ,如 表 1-1 所 示 。 
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表 1-1 ASP 与 ASP. NET 的 对 比 


ASP 


ASP. NET 


用 户 界面 和 实现 逻辑 混合 在 一 个 页 面 中 ,无 法 剥离 


用 户 界面 和 实现 逻辑 可 以 完全 剥离 


程序 员 需 要 严格 区 分 一 个 页 面 中 的 客户 端 程序 与 服 
务 器 端 程序 ,而 且 客户 端 程序 与 服务 器 端 程序 很 难 
交互 


使 用 Web 控件 ,不 再 区 分 客户 端 与 服务 器 端 程 
序 ,可 以 直接 进行 数据 交换 


仅 支持 HTML 标记 


支持 HTML 标记 、 服 务 器 控件 


只 支持 解释 型 语言 ,包括 VBScript 和 JavaScript. 当 
用 户 发 出 请 求 后 ,无 论 是 第 几 次 , ASP 的 页 面 都 被 
动态 解释 执行 


ASP. NET 支持 编译 型 语言 ,包括 Visual Basic 
. NET,C£ „Visual C+. NET,J &. NET, 第 一 次 请 
求 时 要 编译 页 面 , 之 后 再 次 请 求 时 不 需要 重新 编译 


支持 COM 组件 支持 COM 组 件 , 类 库 和 Web Service 组 件 
很 难 调试 和 跟踪 可 以 方便 地 调试 和 跟踪 
不 支持 面向 对 象 编程 支持 面向 对 象 编程 

1.2 运行 环境 配置 


运行 ASP. NET 应 用 程序 ,需要 配置 合适 的 运行 环境 ,其 中 包括 Visual Studio . NET 
集成 开发 环境 的 安装 和 Internet 信息 服务 (IIS) 的 配置 。 


1.2.1 


Visual Studio 2005 集成 开发 环境 


Visual Studio 2005 是 一 个 功能 强大 的 集成 开发 环境 ,在 该 开发 环境 中 可 以 创建 
Windows 应 用 程序 .ASP. NET 应 用 程序 .ASP. NET 服务 和 控制 台 程 序 等 。 


1. 集成 开发 环境 简介 


Visual Studio 2005 集成 开发 环境 如 图 1-1 所 示 , 从 图 中 可 以 看 到 界面 主要 由 几 个 不 同 


的 部 分 组 成 。 


在 进行 页 面 设计 时 需要 用 到 “属性 ”窗口 。 在 此 窗口 中 ,用 户 可 以 对 页 面 的 一 些 属性 值 
进行 设置 ,这 些 设 置 的 属性 值 会 被 自动 添加 到 源 代码 中 。 当 没有 打开 任何 工程 时 ,该 窗口 中 


不 显示 任何 内 容 。 


在 Visual Studio 2005 的 窗口 左 侧 有 一 个 隐藏 的 工具 箱 , 当 用 户 将 鼠标 放置 在 “工具 箱 ” 
按钮 上 时 会 弹出 一 个 “工具 箱 ” 窗 口 ,在 该 窗口 中 列 出 了 开发 ASP. NET 应 用 程序 的 多 种 控 
件 , 用 户 可 以 直接 使 用 这 些 控件 ,节省 了 编辑 代码 的 时 间 , 加 快 了 程序 开发 的 进度 。 和 "* 属 
性 ”窗口 相同 , 当 没有 打开 任何 工程 时 ,这 个 窗口 中 也 没有 任何 内 容 。 


2. 配置 集成 开发 环境 


为 了 便于 阅读 代码 和 对 源 代码 进行 有 条 理 的 说 明 , 可 以 通过 下 列 步骤 设置 集成 开发 环 
境 的 文本 编辑 器 ,使 得 每 行 代码 前 面 都 显示 行 号 。 

D 选择 “工具 ”1“ 选 项 ”命令 ,打开 “选项 "对话 框 。 

(2) 在 “选项 "对话 框 中 展开 “文本 编辑 器 ”节点 ,选择 “所 有 语言 "选项 ,如 图 1-2 所 示 。 

(3) 选中 “ 行 号 " 复 选 框 , 单 击 “ 确 定 ” 按 钮 关闭 该 对 话 框 。 
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1-2 设置 显示 行 号 


可 以 通过 下 列 步骤 设置 集成 开发 环境 的 “环境 ”选项 ,以 便 改变 源 代码 的 字体 .字号 。 
(1) 选择 “工具 ”|“ 选 项 "命令, 打开“ 选项” 对话 框 。 
(2) 在 “选项 "对话 框 中 展开 “环境 ”节点 ,选择 “字体 和 颜色 ”选项 ,如 图 1-3 所 示 。 


ETA 


ZS] 


1-3 改变 字体 和 字号 
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(3) 重新 选择 字体 和 字号 ,然后 单 击 “确定 ”按钮 关闭 该 对 话 框 。 
1.2.2 JIS 的 安装 与 配置 


1. 安装 IIS 
在 Windows 2000 或 Windows XP 中 安装 IIS 的 步骤 如 下 : 
(1) 选择 “开始 ”1“ 控 制 面板 ”|“ 添 加 或 删除 程序 ”命令 ,打开 如 图 1-4 所 示 的 窗口 。 


B 关 加 或 副 除 程序 


D 显示 更 新 中 


围 360 安 全 卫士 


上 次 使 用 日 其 
LET RI m 
CEL 
国 relsee 6.0 PowerPack 
B Adobe Flash Player 10 ActiveX 
[EM Adobe Reader 7.0.5 - Chinese Sinplified 
1B kspwplowa 
B exer 5.5 
[i Conexant 四 Audio 
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(2) 在 窗口 的 左 侧 单 击 “ 添 加 /删除 Windows 组 件 ” 图 标 ,打开 “Windows 组 件 向 导 ” 对 
话 框 ,如 图 1-5 所 示 。 


Tindors 组 件 
可 以 添加 或 删除 Windovs XP 的 组 件 。 


Ean a l i 
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(3) 在 “Windows 组 件 向 导 ” 对 话 框 中 找到 “Internet 信息 服务 (IIS)” 组 件 ,如 果 尚 未 安 
装 , 则 其 左 侧 的 复 选 框 不 会 被 选中 。 如 果 复 选 框 是 不 可 选 状态 ,说 明 TIS 的 组 件 没 有 全 部 安 
装 ;否则 说 明 IIS 已 经 全 部 安装 ,退出 安装 过 程 。 

如 果 复 选 框 没有 被 选中 , 则 选中 该 复 选 框 ;如 果 复 选 框 是 不 可 选 状态 , 则 选中 该 项 , 单 击 
“详细 信息 ”按钮 ,打开 如 图 1-6 所 示 的 对 话 框 。 
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Internet 信息 服务 (IIS) 


要 添加 或 删除 某 个 组 件 ， 请 单 击 半 灰色 框 表示 只 会 安装 该 组 件 的 一 
部 分 。 和 要 查看 组 件 内 容 ， 博 单 击 “ 详 细 信 息 ”. 


Internet 信息 服务 [TS) 的 子 组 件 O: 
C QrrontPage 2000 服务 器 扩展 
Ra Internet 信息 服务 管理 单元 


图 1-6 "Internet 信息 服务 (IIS)” 对 话 框 


(4) 在 “Internet 信息 服务 (IIS)? 对 话 框 中 选择 要 安装 的 子 组 件 ,对 于 本 书 来 说 “公用 
文件 ” 子 组 件 是 一 定 要 选中 的 。 选 择 要 安装 的 子 组 件 后 , 单 击 “ 确 定 ” 按 钮 ,返回 到 “Windows 
组 件 向 导 ” 对 话 框 。 单 击 “ 下 一 步 ” 按 钮 开始 安装 IIS, 此 时 可 能 会 提示 用 户 将 Windows 2000 
系统 盘 放 和 人 光驱 中 。 

(5) 安装 完毕 后 ,返回 到 “添加 或 删除 程序 ”窗口 。 

一 旦 安装 完成 ,系统 会 自动 启动 IIS, 而 且 在 此 之 后 ,无 论 何 时 启动 Windows, 系统 都 会 
自动 启动 TS. 

2. 创建 虚拟 目录 

IIS 安 装 完成 之 后 , 系统 会 自动 建立 一 个 默认 网 站 的 主 目录 ,默认 路 径 为 
[systemdrive]:\Inetpub\wwwroot。 如 果 把 一 个 名 为 xxx. aspx( 或 . htm) 的 文件 放置 在 主 
目录 下 ,那么 就 可 以 通过 http://127. 0. 0. 1/xxx. aspx 访问 该 网 页 。 也 可 以 不 将 网 站 放置 
在 此 目录 下 ,而 为 网 站 设置 虚拟 目录 。 

虚拟 目录 相当 于 物理 目录 在 Web 服务 器 上 的 别名 , 它 不 仅 使 用 户 避 免 了 宛 长 的 URL, 
而 且 是 一 种 很 好 的 安全 措施 ,因为 虚拟 目录 对 所 有 浏览 者 隐藏 了 物理 目录 结构 。 例 如 ,为 
D:\aspcode\ks 目录 创建 虚拟 目录 ,步骤 如 下 : 

(1) 打开 “Internet 信息 服务 ”窗口 , 右 击 “ 默 认 网 站 ”节点 ,在 弹出 的 快捷 菜单 中 选择 “新 
建 ”|“ 虚 拟 目 录 ” 命 令 , 如 图 1-7 所 示 。 

(2) 在 打开 的 “虚拟 目录 创建 向 导 ” 对 话 框 中 ,直接 单 击 “ 下 一 步 ”按钮 ,打开 如 图 1-8 所 
示 的 对 话 框 ,输入 一 个 别名 ,这 里 输入 “ks”, 与 它 的 物理 目录 的 名 称 相同 。 

(3) 单 击 “ 下 一 步 ? 按 钮 ,在 打开 的 对 话 框 中 单 击 “ 浏 览 ?按钮 ,选择 虚拟 目录 对 应 的 Web 
服务 器 的 物理 目录 ,如 图 1-9 所 示 。 

(4) 单 击 “ 下 一 步 ? 按 钮 ,打开 图 1-10 所 示 的 “访问 权限 ?对 话 框 。 默 认 权 限 为 “ 读 取 ”和 
“运行 脚本 ”。 这 些 权 限 是 服务 器 上 所 有 ASP. NET 应 用 程序 的 公共 权限 。 

(5) 单 击 “下 一 步 ? 按 钮 ,然后 单 击 “ 完 成 按钮 , 即 可 完成 虚拟 目录 的 创建 。 此 时 ,在 
"Internet 信息 服务 ”窗口 的 目录 树 中 就 会 显示 虚拟 目录 ks, 如 图 1-11 所 示 。 

可 以 右 击 图 1-11 中 的 虚拟 目录 ks, 从 弹出 的 快捷 菜单 中 选择 “属性 ?命令 ,打开 图 1-12 
所 示 的 对 话 框 ,在 此 对 话 框 中 重新 设置 虚拟 目录 的 访问 权限 。 
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VALL : 


所 有 任务 到 ) 
查看 


ECT 
BED 
SHIRE (D 


REO 
EHW 


图 1-7 “ME EMER’ AS 


虚拟 目录 创建 向 导 虚拟 目录 创建 向 导 
虚拟 目录 别名 同 站 内 容 目录 
必须 为 虚拟 目录 提供 一 个 简短 的 名 称 或 别名 ， 以 便于 快速 引用 。 要 发 布 到 网 站 上 的 内 容 的 位 置 。， 


Nd eb 录 访 问 权限 的 别名 。 使 用 的 命名 规 输入 内 容 所 在 的 目录 路 径 。 
RAE em 


3/80 [D:\aspcode\ks AEW... 
fesl 


《上 一 步 吧 ) 取消 


图 1-8 “虚拟 目录 别名 ”对 话 框 图 1-9 选择 网 站 的 物理 目录 


虚拟 目录 创建 向 导 
访问 权限 


Y Internet 信息 服务 

Xi) 操作 名) SEV 帮助 加 
Tv EG n Asp G) e» fmm xig S 2 |» 
厂 执行 Qo ISAPI 应 用 程序 或 C6T) QD CR 名 称 


T SAU pee 
r ARO TEN. — 
单 击 “ 下 一 步 ” BARRAS- 


IISHelp 
jxpj 
Printers 
Asplipload 


tasech 


eT rz mA 


图 1-10 “访问 权限 ?对 话 框 图 1-11 新 创建 的 虚拟 目录 
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虚拟 目录 [文档 | 目录 安全 性 [HTTP 头 | BELMA | ase. mer] 
连接 到 这 源 时 的 内 容 来 源 
OSGTESLEBESE QU 
〇 另 一 各 计 算 机 上 的 共享 (8) 
OTAN WLU 


本 地 路 径 O: p: Naspeode\ks 


Ostman [xri w 
[eii aD [ssim 
OZAY 


应 用 程序 名 W: 
开始 位 置 : 

执行 权限 四) 

应 用 程序 保护 W: 


图 1-12 “ks 属性 ”对 话 框 


1.3 创建 简单 的 ASP. NET 应 用 程序 


ASP. NET 的 运行 环境 配置 好 后 ,就 可 以 开发 ASP. NET 应 用 程序 了 。 下 面 通过 实例 
介绍 在 Microsoft Visual Studio 2005 中 如 何 编写 ASP. NET 应 用 程序 。 


1. 创建 Web 站 点 
(D 启动 Microsoft Visual Studio 2005, 
(2) 选择 “文件 ”1“ 新 建 ”"1“ 网 站 ”命令 ,打开 “新 建 网 站 ”对 话 框 ,如 图 1-13 所 示 。 


LUUD 
Visual Studio 已 安装 的 模板 


GS eT Fi ASEET ve 服务 
LE] JAISE. NET Crystal Eeports Y. 


meu 
Ternan 


M C: netpub reeroot 
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(3) 在 “Visual Studio 已 安装 的 模板 ?列表 中 选择 “ASP. NET 网 站 ”选项 。 
(4) 在 “位 置 " 下 拉 列 表 框 中 选择 “文件 系统 ”选项 ,然后 输入 要 创建 的 站 点 的 物理 位 置 ， 
如 “D:\aspcode\ks”。 如 果 某 个 文件 夹 不 存在 , 则 系统 会 自动 创建 。 
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(5) 在 “语言 "下 拉 列 表 框 中 选择 “Visual C# ”选项 , 单 击 “确定 ”按钮 , 则 在 集成 开发 环 
境 中 将 创建 该 文件 夹 和 一 个 名 为 Default. aspx 的 新 页 ,如 图 1-14 所 示 。 


ZPD Mo WBV REO #0 MD IAD AO SMO #0 -— 


- p NAE ks" à 个 项 目 ) 

2 El a- da Dae ode! "un 
3 «IDOCTYPE htal PUBLIC '-//W3C//DTD m 

4 


58 htal xalns- http: //rvv, v3, org/1999/xhta 
65 head. runat="server” 

T 《title? 无 标题 页 </title> 

8 上 </head> 
9E «body? 


图 1-14 新 建 ks 站 点 
选择 “文件 "| * 关 闭 解 决 方案 ?命令 , 则 可 以 关闭 当前 站 点 ;选择 “文件 "| * 打 开 ”|* 网 站 ?” 
命令 , 则 可 以 打开 某 个 站 点 。 
2. 编写 ASP.NET 应 用 程序 


【 例 1-1】 在 站 点 ks 中 设计 一 个 登录 页 面 , 初 始 界面 如 图 1-15 所 示 ,用户 输 入 学 号 和 
姓名 , 单 击 “ 登 录 ” 按 钮 时 ,就 能 在 标签 中 显示 “欢迎 **x*_xxx 使 用 本 系统 !" 的 字样 。 


1-15 f 1-1 初始 界面 


为 站 点 ks 创建 登录 页 面 login. aspx 的 步骤 如 下 : 

(D 启动 Microsoft Visual Studio 2005, 

(2) 选择 “文件 ?| 打开 ”|* 网 站 ?命令 ,打开 “打开 网 站 ?对 话 框 ,如 图 1-16 所 示 。 在 其 
中 选择 要 打开 的 文件 夹 ” D:\aspcode\ks”。 

G) 单 击 “ 打 开 ” 按 钮 ,就 可 以 打开 如 图 1-14 所 示 的 集成 开发 环境 , 右 击 “解决 方案 资源 
管理 器 ”窗口 中 的 站 点 物理 目录 “D:\aspcode\ks\”, 从 弹出 的 快捷 菜单 中 选择 “添加 新 项 ” 命 
令 , 打 开 “ 添 加 新 项 ”对 话 框 ,如 图 1-17 所 示 。 

(4) 在 “Visual Studio 已 安装 的 模板 ”列表 中 选择 “Web 窗 体 ” 选 项 ,在 “名 称 ” 文 本 框 中 
输入 login. aspx, 在 “语言 "列表 框 中 选择 “Visual C#” 选 项 ,选中 “将 代码 放 在 单独 的 文件 
mr E dE 


区 


选择 要 打开 的 文件 夫 O. 
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添加 新 项 - d: \aspcode\ks\ 
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图 1-17 “添加 新 项 ”对 话 框 


(5) 单 击 “添加 ”按钮 ,就 在 “解决 方案 资源 管理 器 ”窗口 中 的 ks 站 点 下 面 添 加 login. 


aspx 文件 了 。 


(6) 双击 login. aspx 文件 ,选择 “设计 ”选项 卡 ,在 设计 视图 中 创建 如 图 1-15 所 示 的 初 


始 界面 。 各 控件 的 属性 设置 见 表 1-2。 
表 1-2 各 控件 的 属性 设置 


控 件 属 性 值 控 件 属 性 值 
Text 系统 登录 TextBox2 
Labell 
Font-Size Large Buttonl Text 登录 
Label2 Text 学 号 Text 
Label3 Text 姓名 Label4 
TextBoxl ForeColor Blue 
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CD 双击 “登录 ”按钮 ,打开 代码 隐藏 文件 login. aspx. cs。 在 “登录 ”按钮 的 Click 事件 
中 添加 以 下 代码 : 


protected void Buttonl Click(object sender, EventArgs e) 
t 
String a-TextBoxl.Text; 
String b- TextBox2. Text; 
Llabel4.Text- "欢迎 "+ at+ " "+b+ "使 用 本 系统 !1"; 
) 
(8) 选择 “调试 ?|* 启 动 调试 命令 ,编译 运行 程序 ,最 终 的 运行 界面 如 图 1-18 所 示 。 


要 无 标题 页 - Jicrosoft Internet Explorer — [- fX) 
; KD REO SEV KEW IAV 帮助 0) [7] 


系统 登录 
#5. 123 
姓名 ， We 


E 


欢迎 123 张 三 使 用 本 系统 | 


148 f 1-1 运行 界面 


如 果 对 站 点 D:\aspcode\ks\ 设 置 了 虚拟 目录 ks, 则 运行 login. aspx 的 方法 是 : 先进 入 
正 浏览 器 ,然后 在 地 址 栏 中 输入 “http://localhost/ks/login. aspx”. 


1.4 项 目 实 训 


实 训 1 创建 虚拟 目录 
实 训 目的 
(1) 了 解 IIS 的 安装 方法 。 
(2) 了 解 建立 虚拟 目录 的 意义 。 
(3) 掌握 虚拟 目录 的 创建 过 程 。 
实 训 要 求 
在 TIS 中 创建 一 个 名 为 test 的 虚拟 目录 ,其 对 应 的 物理 目录 为 D:\ASP. net\sx01。 


实 训 2 创建 一 个 Web 应 用 程序 


实 训 目的 
(1) 了 解 Visual Studio 2005 集成 开发 环境 的 组 成 。 
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(2) 掌握 创建 ASP. NET 应 用 程序 的 步骤 。 
G) 掌握 ASP. NET 应 用 程序 的 创建 ,调试 和 运行 。 


实 训 要 求 

CD 在 实 训 1 建立 的 虚拟 目录 test 中 创建 一 个 页 面 sxl_1. aspx, 输 入 个 人 信息 ,界面 如 
图 1-19 所 示 。 单 击 “ 确 认 ” 按 钮 ,将 输入 的 个 人 信息 显示 在 Labels 控件 中 ,输出 结果 如 
图 1-20 所 示 。 


PELLE Wicrosoft 1... LOR) 


| 文件 中 REO SEV wo" dr PARERES 


个 人 信息 填写 表 i 起 云 


21 
[gsk. rk. hg 


GR 


您 输入 的 个 人 信息 是 : 
姓名 : 赵云 ; 


年 龄 : 21; 
爱好 : 篮球 、 游 泳 、 旅游 


图 1-19 初始 界面 图 1-20 输出 界面 


(2) 在 实 训 1 建立 的 虚拟 目录 test 中 创建 一 个 页 面 sxl 2. aspx, 要 求实 现 两 个 文本 框 
中 数据 的 交换 ,如 图 1-21 所 示 。 


区 无 标题 页 - Nicrosoft Internet Explorer DER 
; D 编辑 EE) SEV KEW IAW #HW m 


交换 文本 框 中 的 数据 


sme [D 
sae o [ 0 jJ 
p 


图 1-21 sxl 2.aspx 页 面 


思考 与 练习 


一 、 填空 题 

1. ASP 支持 语言 ,ASP. NET 支持 语言 。 

2. .NET 是 公司 发 布 的 新 一 代 系 统 、 服 务 和 编程 平台 ,主要 由 和 
组 成 。 


3. 动态 网 页 是 指 页 面 ,其 扩展 名 一 般 为 
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二 、 简 答题 

1. 什么 是 虚拟 目录 ? 

2. 为 D:\personNabc 创建 虚拟 目录 abc, 在 abc 目录 下 创建 网 页 default. aspx。 通 过 输 
人 “http://127.0.0.1/default. aspx” 访 问 ,是 否 成 功 ? 然后 将 “127. 0. 0. 1” 换 成 “localhost” 
(或 当前 计算 机 名 ) ,效果 如 何 ? 车 希望 在 省 略 文件 名 的 情况 下 仍 能 访问 该 网 页 ,该 如 何 
操作 ? 


C# 的 中 文 译音 暂时 没有 , 非 专 业 人 士 一 般 读 作 “C JE" ,专业 人 士 一 般 读 作 *C sharp". 

C# 是 一 种 安全 的 稳定 的 ,简单 的 ,优雅 的 ,由 C 和 C++ 衍 生出 来 的 面向 对 象 的 编程 语 
言 。 它 在 继承 C 和 C++ 强 大 功能 的 同时 去 掉 了 一 些 复杂 的 特性 (例如 没有 宏和 模板 ,不 允 
许多 重 继承 )。C# 综 合 了 Visual Basic 简单 的 可 视 化 操作 和 C++ 的 高 运行 效率 ,以 其 强大 
的 操作 能 力 \ 优 雅 的 语法 风格 、 创 新 的 语言 特性 和 便捷 的 对 面向 组 件 编程 的 支持 成 为 . NET 
开发 的 首选 语言 ,并 且 C# 成 为 ECMA 与 ISO 标准 规范 。C# 看 似 基于 C++ 写成 ,但 又 融 
和 人 了 其 他 语言 ,如 Pascal, Java, Visual Basic 等 。 


ZIARA 


。 掌握 C# 的 数据 类 型 
Og CE 的 基本 语句 
。 学 会 C# 的 异常 处 理 机 制 
。 掌握 C# 的 类 和 对 象 
。 了 解 命名 空间 的 含义 
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2.1.1 CHS 


C# 是 微软 公司 研究 员 Anders Hejlsberg 的 最 新 成 果 。C# 是 用 于 编写 可 运行 在 . NET 
CLR 上 的 应 用 程序 的 语言 之 一 。 它 从 C 和 C++ 语言 演化 而 来 ,是 Microsoft 专门 为 用 户 使 
用 . NET 平台 而 创建 的 。C# 是 近期 发 展 起 来 的 ,所 以 吸取 了 以 前 的 教训 ,考虑 了 其 他 语言 
的 许多 优点 : 回归 了 C 语言 的 简约 语法 ,传承 了 C++ 语言 的 功能 机 制 ,借鉴 了 Java 语言 的 
典雅 风格 ,形成 了 一 种 易学 易 用 的 新 兴 语 言 。C# 语 言 具 有 以 下 特征 。 

1. 简约 

C# 语 言 的 复杂 性 比 C++ 降低 了 。 最 为 典型 的 表现 之 一 就 是 C# 去 掉 了 C++ 中 虽然 
功能 强大 ,但 容易 出 错 、 普 通 程序 员 难 以 把 握 的 指针 类 型 。 这 一 改进 并 未 减弱 C# 的 灵活 
性 ,通过 托管 内 存 执行 代码 机 制 ,使 用 如 委托 .迭代 器 、 匿 名 方法 和 扩展 方法 等 机 制 ,提供 了 
比 指针 更 为 强大 ,灵活 的 功能 。 


16 


ASP. NET 网 站 开发 案例 教程 


2. 安全 

C# 语 言 采用 严格 的 类 型 检查 ,保证 在 安全 的 范围 内 进行 类 型 转换 ,并 通过 封 箱 和 拆 箱 
操作 ,实现 值 类 型 到 应 用 类 型 的 安全 转换 。 这 种 类 型 的 安全 检查 能 够 确保 所 有 变量 从 初始 
化 到 销毁 的 整个 生命 周期 内 都 位 于 受托 管内 存 中 。 通 过 受托 管内 存 的 类 型 检查 和 垃圾 回收 
机 制 ,提高 了 程序 的 稳定 性 ,避免 了 传统 程序 控制 不 当 导 致 的 内 存 泄露 。 


3. 现代 

Cz 语言 结合 了 许多 编程 语言 的 优点 ,并 且 针 对 不 同 领域 应 用 程序 的 开发 需要 而 改善 。 
相对 于 C 语言 .C++ 和 Java,C# 在 语义 上 做 出 了 重大 改进 和 扩展 ,如 委托 、 匿 名 方法 ， 
CH 3.0 的 扩展 方法 .Lambda 表达 式 等 。 这 种 改进 和 扩展 不 仅 使 C# 编程 变 得 更 加 灵活 ， 
而 且 使 C# 语言 更 符合 业界 的 发 展 趋势 ,形成 更 高 的 生产 力 。 


4. RE 

C# 语 言 要 适合 广泛 的 应 用 领域 ,就 必须 兼容 传统 的 应 用 程序 。 为 此 ,C# 不 仅 能 够 通 
过 COM 互 操作 与 以 往 的 组 件 兼容 ,还 能 通过 声明 的 入 口 点 访问 任何 DLL 库 。 这 些 DLL 
库 可 以 是 托管 代码 生成 的 ,也 可 以 是 非 托管 代码 生成 的 。 


2.1.2 第 一 个 C# 程 序 


本 节 将 以 创建 一 个 控制 台 程 序 为 例 , 介 绍 利 用 Microsoft Visual Studio 2005 集成 开发 
环境 创建 C# 应 用 程序 的 过 程 。 

【 例 2-1】 创建 一 个 控制 台 应 用 程序 2-1, 要 求 : 在 控制 台 屏 幕 上 输出 “欢迎 进入 CR 
世界 1”。 

步骤 如 下 : 

(1) 启动 Microsoft Visual Studio 2005。 

(2) 选择 “文件 ”1“ 新 建 ”1“ 项 目 ” 命 令 ,打开 “新 建 项 目 ” 对 话 框 ,如 图 2-1 所 示 。 


guo: 
Visual Studio 已 安装 的 模板 
tindo: 应 用 程序 pee 
Bindon: 控件 库 s Rit 
ilerystal Reports 应 用 程序 
Eine Iff 


Glock 外 接 程 序 
EMEK 


graman 


个 人 教学 资料 \ 教 材 编 写 \ 滞 华 大 学 出 版 社 \ 宗 例 a| [ane o. 
i [chap02 回 创建 解决 方案 的 目录 QD 


m mf un 


2.1 “新 建 项 目 ” 对 话 框 


(3) 在 “项 目 类 型 "列表 中 选择 “Visual CH ”选项 ,在 “模板 ”中 选择 “控制 台 应 用 程序 ” 选 
项 ,在 “名 称 ”文本 框 中 输入 项 目的 名 称 *2-1”, 选 中 “创建 解决 方案 的 目录 " 复 选 框 ,在 “解决 
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方案 名 称 ” 文 本 框 中 输入 解决 方案 的 名 称 , 如 “chap02”, 在“ 位置" 文本 框 中 选择 解决 方案 文 
件 夹 的 位 置 。 
(4) 单 击 “ 确 定 ” 按 钮 , 即 可 打开 控制 台 代 码 编辑 界面 ,如 图 2-2 所 示 。 


1Eusing System; 
2 | seine Systen. Collections. Generic; 
S -using Systen. Text; 


5 日 nanespace |. 1 


E 
class Program 
nor void Main(string[] args) 


WriteLine(“ 欢 迎 进入 C# 世界 !“); 
ReadO ; 


2-2 代码 编辑 界面 


(5) 最 后 ,选择 “调试 ”1“ 启 动 调试 "命令 运行 程序 。 

Microsoft Visual Studio 2005 使 用 “解决 方案 "来 管理 网 站 和 项 目 ,一 个 解决 方案 只 包 
含 一 个 网 站 ,但 一 个 解决 方案 可 以 包含 多 个 项 目 ,并 且 可 以 将 任 一 项 目 设 为 启动 项 目 。 

在 解决 方案 中 添加 新 项 目的 方法 为 : 右 击 
图 2-2 中 的 “解决 方案 “chap02”” 节 点 ,在 弹出 的 
快捷 菜单 中 选择 “添加 ”1 “新建 项 目 ” 命 令 , 如 
图 2-3 所 示 。 

若 一 个 解决 方案 包含 多 个 项 目 , 则 要 运行 某 
个 项 目 ,必须 右 击 该 项 目 , 在 弹出 的 快捷 菜单 中 
选择 “ 设 为 启动 项 目 ” 命 令 。 创 建 一 个 项 目 会 自 
动 生成 一 个 文件 夹 ,其 中 包括 两 个 重要 文件 : 


CEHEC es) ,项 目 文件 (. esproj)。 | e 
C# 源 文件 的 组 成 层次 如 下 ， Rip WR AS 
CD 每 个 C# 源 文件 由 一 个 或 多 个 命名 空 

间 组 成 。 


(2) 每 个 命名 空间 包含 3 部 分 : using 语句、 类 、 子 命名 空间 。 

(3) 每 个 类 的 作用 域 可 以 都 是 public, 且 源 文件 名 是 任意 的 。 

CD 每 个 C# 源 文件 都 存在 一 个 全 局 命名 空间 ,用 户 声明 的 命名 空间 只 是 全 局 命名 空 
间 的 一 个 成 员 。 

(5) 一 个 C# 程 序 有 且 只 有 一 个 Main() 函 数 ,作为 运行 人 口 。 

(6) 最 简单 的 C# 程 序 只 有 一 个 类 ,该 类 只 包含 一 个 Main() 函数。 

f] 2-1 的 C# 程 序 可 以 简化 为 : 
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class Program 
t 
static void Main (string[]args) 
{ 
System.Console.WriteLine ("欢迎 进入 C# 世 界 1") ; 
System.Console.Read (); 


} 
C# 是 区 分 字母 大 小 写 的 语言 。 下 面 介绍 输出 语句 、 输 入 语句 和 C# 的 注释 。 
(1) 输出 语句 


System.Console.WriteLine (输出 格式 ,表达 式 ) 
System.Console.Write (输出 格式 ,表达 式 ) 


“输出 格式 ?是 由 普通 字符 与 格式 字符 组 成 的 字符 串 。 有 多 少 个 表达 式 ,就 必须 有 多 少 
个 格式 字符 。 若 只 有 一 个 表达 式 , 则 可 以 省 略 格式 字符 。 例 如 ， 


System.Console.WriteLine("(0), (1)",i,); 
System.Console.Write (i); 


(2) 输入 语句 


int 变量 名 =System.Console.Read(); 
string 变量 名 =System.Console.ReadLine () ; 


前 者 用 于 接收 一 个 字符 ,并 返回 该 字符 的 Unicode 码 ; 后 者 用 于 接收 一 个 字符 串 ， 
(3) C# 的 注释 

单行 注释 :// 注 释 内 容 

多 行 注释 :/* 注释 内 容 * / 
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C# 将 数据 类 型 分 为 两 大 类 : 值 类 型 和 引用 类 型 。 两 者 的 区 别 是 : 值 类 型 的 变量 直接 
存储 数据 的 值 ;引用 类 型 的 变量 不 直接 存储 数据 的 值 ,存储 的 只 是 数据 的 引用 地 址 。 图 2-4 
说 明了 值 类 型 和 引用 类 型 的 区 别 。 


string str- " China " : 
str 


inta-l; 地 址 
a x 

1 C|hli|n|a 
值 类 型 引用 类 型 


图 2-4 值 类 型 和 引用 类 型 的 区 别 


第 2 章 C# 语 言 基础 


2.2.1 值 类 型 
(1) 整 型 : 见 表 2-1。 
X21 £8 
C# 类 型 . NET 类 型 所 占 字 节 数 取 值 范围 
byte System. Byte 1 0 一 255( 无 符号 ) 
sbyte System. SByte —128— 127( 有 符号 ) 
short System. Int16 2 —32768~ 32767 
int System. Int32 4 
long System. Int64 8 
(2) 浮 点 型 : 见 表 2-2。 
R22 FAM 
C# 类 型 . NET 类 型 所 占 字 节 数 取 值 范围 
float System. Single 4 以 下 或 {结尾 的 实数 
double System. Double 8 
G) 字符 型 : 见 表 2-3。 
表 2-3 字符 型 
Caen .NET 类 型 所 占 字 节 数 取 值 范围 
char System. Char 2 0 一 65535 对 应 的 字符 


C & X JI] Unicode 编码 ,每 个 字母 .数字 、 汉 字 都 算 一 个 字符 。 在 C# 中 整数 类 型 无 法 转 
换 为 字符 型 ,因此 ,char 型 变量 只 能 赋 上 一 个 字符 ,不 能 赋 上 字符 的 Unicode。 例 如 : 


char x= 'A'; 
而 不 能 使 用 
char x- 65; 
(4) 布尔 型 : 见 表 2-4, 
R24 布尔 型 
C# 类 型 .NET 类 型 所 占 字 节 数 取 值 范围 


bool System. Boolean 1 true 或 false 


2.2.2 引用 类 型 
C# 中 有 两 种 预定 义 引 用 类 型 , 见 表 2-5. 
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表 2-5 引用 类 型 
CHH . NET 类 型 取 值 范围 C# 类 型 .NET 类 型 取 值 范围 


string System. String 任意 一 个 字符 串 object System. Object | 任意 类 型 的 数据 


23 常量 、 变 量 和 运算 符 

2.3.1 常量 

所 谓 常量 ,就 是 在 程序 运行 过 程 中 其 值 不 能 改变 的 量 。C# 的 常量 有 如 下 几 种 。 

1. 整 型 常量 

整 型 常量 就 是 一 个 整数 ,例如 : 100、314。 

2. 浮 点 型 常量 

浮 点 型 常量 分 为 单 精 度 常 量 (float) 和 双 精 度 常 量 (double)。 单 精度 常量 以 Ff 或 f 结 
尾 , 双 精度 常量 以 D 或 4 结尾 。 如 果 没 有 这 些 说 明 ,系统 会 把 浮 点 数 作为 double 类 型 处 理 。 
例如 ,3. 14F、3. 14f 是 float 型 常量 ,3. 14,3. 14D,3. 14d 是 double 型 常量 。 

3. 字符 型 常量 

字符 型 常量 是 用 单 引号 括 起 来 的 一 个 字符 ,例如 : 'a'、' 汕 '。 另 外 ,C# 也 提供 转 义 字符 ， 
以 反 斜 枉 (\) 开 头 , 将 其 后 的 字符 转变 为 另外 的 含义 , 表 2-6 列 出 了 常见 的 转 义 字符 。 


R26 转 义 字符 
转 义 字符 含义 转 义 字符 & X 
\n 换行 ,将 光标 移 到 下 一 行 开头 M 代表 一 个 单 引号 字符 
M 跳 到 下 一 个 Tab 位 置 M 代表 一 个 双 引 号 字符 
\b 退 格 \ddd 1 一 3 位 八进制 数 所 代表 的 字符 
\r 回 车 ,将 光标 移 到 本 行 开头 \uxxxx 1 一 4 位 十 六 进 制 数 所 代表 的 字符 
\\ 代表 一 个 反 斜 杠 字 符 
4. 字符 串 常量 
字符 串 常量 是 用 双 引 号 括 住 的 一 个 或 多 个 字符 ,例如 : "e" v" student". 
5. 逻辑 型 常量 


逻辑 型 常量 只 有 两 个 : true,false。 
另外 ,C# 还 可 以 通过 const 把 一 个 标识 符 定义 为 常量 ,定义 符号 常量 的 语法 如 下 : 


const 类 型 名 符号 常量 = 常量 表达 式 ; 


其 中 ,const 是 C# 的 关键 字 , 表 示 要 声明 一 个 符号 常量 ;类 型 名 用 来 指定 这 个 符号 常量 
的 类 型 ;二 表示 赋值 ;常量 表达 式 是 这 个 符号 常量 的 值 。 例 如 : 


const string s=" F"; 
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数学 中 的 圆周 率 被 用 到 程序 中 时 , 它 的 值 是 不 能 改变 的 ,同时 也 不 希望 在 程序 运行 期 间 
被 误 改 ,就 可 以 用 符号 常量 来 定义 。 


public const double PI-3.14159; 


2.3.2 变量 


所 谓 变 量 , 就 是 在 程序 运行 过 程 中 其 值 可 以 改变 的 量 。 变 量 的 类 型 可 以 是 C# 的 任何 
一 种 数据 类 型 。 变 量 必须 遵循 “ 先 定义 后 使 用 ”的 原则 ,变量 的 定义 格式 如 下 : 


类 型 变量 名 [= 初 值 ]; 


由 定义 格式 可 以 知道 ,变量 在 定义 时 可 以 设置 初始 值 ,也 可 以 不 设置 。 下 面 给 出 各 种 变 
量 的 定义 。 


int a=10; 

float b=3.14F; 

double c=3.14; 

char ch- "ill '; 

bool x-true; 

string str- "student"; 

object obj- 123; 

在 定义 变量 时 要 注意 如 下 几 点 。 

(1) 变量 名 必须 符合 C# 的 命名 规则 : 必须 以 字母 或 下 画 线 开 头 ,变量 名 中 不 能 含有 特 
殊 符 号 ,如 /\、.* L8 .空格 等 。 

(2) 在 变量 的 声明 语句 中 ,允许 对 变量 的 值 进行 初始 化 。 

(3) 在 一 条 变量 声明 语句 中 可 以 声明 多 个 同类 型 的 变量 ,但 对 于 不 同类 型 的 变量 ,必须 
在 不 同 的 语句 中 进行 声明 。 
2.3.3 运算 符 

运算 符 是 表示 各 种 不 同 运算 的 符号 。C# 和 Java 一 样 , 共 引进 14 级 运算 符 。 按 参加 运 
算 的 操作 数 的 个 数 划 分 ,可 以 将 运算 符 分 为 3 类 : 单 目 运算 符 、 双 目 运算 符 和 三 目 运算 符 ; 


按 功能 划分 ,可 以 将 运算 符 分 为 7 类 : SORGE SETTE XE SETTE GE BS ETE IR TERES ETT. 
赋值 运算 符 .位 运算 符 和 移 位 运算 符 。 表 2-7 列 出 了 C# 中 常用 的 运算 符 。 


表 2-7 C# 中 常用 的 运算 符 


优先 级 im * 符 LEES: 结合 性 
à O 圆 括号 自 左 向 右 
2 于 二 一 自 增 、 自 减负 号 ,逻辑 非 、 按 位 取 反 自 右 向 左 
3 * A% 3E RRR 自 左 向 右 
4 du 加 \ 减 自 左 向 右 
5 xx EB AE 自 左 向 右 
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续 表 
优先 级 运 算 do xk 结合 性 
6 ER 大 于 ,大 于 等 于 ,小 于 ,小 于 等 于 自 左 向 右 
7 == = 等 于 ,不 等 于 自 左 向 右 
8 & 按 位 与 自 左 向 右 
9 按 位 异 或 自 左 向 右 
10 | 按 位 或 自 左 向 右 
1 8.8. 逻辑 与 自 左 向 右 
12 II 逻辑 或 自 左 向 右 
13 ? 条 件 运算 符 自 右 向 左 
14 —d-—-a4—-.34- 赋值 运算 符 自 右 向 左 
下 面 介绍 各 类 运算 符 的 用 法 。 
1. 算术 运算 符 


CD 双 目 运算 符 : 十 ,一 、* VU 


当 /、% 两 侧 为 整数 时 ,结果 为 整数 ,例如 : 3/5 二 0,3%5 二 3。 当 /、% 两 侧 有 一 个 为 实数 
时 ,结果 为 实数 。 在 C# 语 言 中 进行 “数值 十 字符 串 ” 的 运算 时 ,要 先 统一 为 字符 串 , 再 运算 ， 


例如 : "12"+34="1234". 


(2) 单 目 运算 符 : 十 十 ( 自 增 ) 一 一 ( 自 减 ) 
O 十 十 .一 一 只 能 作用 在 变量 上 ,不 能 作用 在 常量 和 表达 式 上 。 
Q) i 十 十 .十 十 i 单独 成 为 语句 时 ,均等 价 于 iil. 


Gi i 的 不 同 之 处 是 : i 十 十 是 先 使 用 i, 再 使 i 的 值 加 1; 十 十 i 则 是 先 使 i 的 值 


加 1, 再 使 用 i。 


【 例 2-2】 分 析 程 序 的 运行 结果 。 


Class Program 


{ static void Main (string[] args) 


{ 
int i=0; 


itt; 


System.Console.WriteLine (i); 
System.Console.Read() ; 


i 
运行 结果 : 


1 


【 例 23]. 分 析 程序 的 运行 结果 。 


Class Program 


第 2 章 C# 语 言 基础 


{ static void Main (string[] args) 
{ 
4nt 1,3; 
i-3; 
j=i++; 
System.Console.WriteLine (i+","+j); 
i=3; 
j=++i; 
System.Console.WriteLine (i+","+j); 
System.Console.Read () ; 


运行 结果 : 
4,3 
4,4 
算术 运算 符 的 优先 级 见 表 2-8. 
表 2-8 算术 运算 符 的 优先 级 
运算 符 优先 级 结合 运算 符 优先 级 结合 性 
十 十 ,一 一 2 自 右 向 左 十 .一 4 自 左 向 右 
* JM 3 自 左 向 右 


由 算术 运算 符 组 成 的 表达 式 称 为 算术 表达 式 , 算 术 表达 式 的 值 是 一 个 整数 或 实数 。 
2. 关系 运算 符 
关系 运算 符 的 优先 级 见 表 2-9 。 

表 2-9 关系 运算 符 的 优先 级 


关系 运算 符 用 于 实现 操作 数 的 比较 运算 ,由 关系 运算 符 组 成 的 表达 式 称 为 关系 表达 式 。 
关系 表达 式 的 值 为 true 或 false, 例 如 ,7 二 ==7 的 值 为 true, 


3. 逻辑 运算 符 
逻辑 运算 符 的 优先 级 见 表 2-10。 
表 2-10 逻辑 运算 符 的 优先 级 


运算 符 优先 级 举 例 解 m" 
! 2 Ix 
&. 8. 11 x& &y RÀ x y 有 一 个 为 假 ,结果 即 为 假 
E 12 xlly 只 要 x、y 有 一 个 为 真 ,结果 即 为 真 
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参加 逻辑 运算 的 操作 数 必须 为 逻辑 值 。 由 逻辑 运算 符 组 成 的 表达 式 称 为 逻辑 表达 式 。 罗 
辑 表达 式 的 值 为 true 或 false, 例如 ,2 十 3 之 7 6.8. 7 一 9 是 一 个 逻辑 表达 式 , 它 的 值 为 false。 

若 一 个 表达 式 中 含有 多 种 运算 符 , 则 表达 式 的 类 型 取决 于 级 别 最 低 的 运算 符 的 类 型 。 

4. 条 件 运算 符 

CH 中 唯一 的 一 个 三 目 运 算 符 就 是 条 件 运算 符 (?: ) ,由 条 件 运 算 符 组 成 的 表达 式 称 为 
条 件 表达 式 , 条 件 表 达 式 的 一 般 格 式 为 : 

操作 数 1? 操 作 数 2: 操 作 数 3 


其 中 ,“ 操 作 数 1 的 值 必须 为 逻辑 值 ,否则 将 出 现 编译 错误 。 进 行 条 件 运 算 时 ,首先 判 
断 “ 操 作 数 1 是 否 为 真 , 如 果 * 操 作 数 1 为 真 , 则 条 件 表达 式 的 值 为 “操作 数 2” 的 值 ;如 果 为 
假 , 则 条 件 表达 式 的 值 为 “操作 数 3” 的 值 。 在 例 2-4 的 程序 段 中 ,c 的 值 为 一 10, 因 为 a>b 
的 值 为 false。 

【 例 2-4】 条 件 表达 式 示 例 。 

int a-3; 

int b-5; 

int c-a»b?100 : - 10; 

注意 : 条 件 表达 式 具有 “ 右 结合 性 ”, 意 思 是 操作 自 右 向 左 组 合 。 例 如 ,a?b:c?d:e 表达 
式 的 计算 与 a?b:(c?d:e) 相 同 。 


5. 赋值 运算 符 
(1) 赋值 运算 符 
赋值 运算 符 包括 = 二、 十 = 一 = 二、* 三 、/ 三 、% 三 ,它们 的 优先 级 为 14 ,结合 性 是 自 右 向 


左 。 例 如 ,“a=b=c=4;” 语 句 表 示 a、bc 的 值 均 为 4。 
表 2-11 列 出 了 复合 赋值 运算 符 的 含义 。 
表 2-11 复合 赋值 运算 符 


赋值 运算 符 举 例 * X 赋值 运算 符 举 例 含 A 
+= at-b a=a+b /= a/=b a=a/b 
一 一 a 一 一 b a—a—b %= a%=b a=a%b 
# 一 ax 一 bb a—a*b 
(2) 赋值 表达 式 
赋值 表达 式 的 值 等 于 被 赋值 的 变量 的 值 。 例 如 ,表达 式 a=5 的 值 为 5。 

24 数 组 


数组 是 包含 若干 个 相同 类 型 数据 的 集合 ,数组 的 数据 类 型 可 以 是 任何 类 型 。 数 组 可 以 
是 一 维 的 ,也 可 以 是 多 维 的 (常用 的 是 二 维 数组 和 三 维 数组 )。 


2.4.1 一 维 数组 
数组 的 维 数 决定 了 数组 元 素 的 下 标 数 ,一 维 数组 只 有 一 个 下 标 。 一 维 数组 的 声明 格式 
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WF: 

类 型 [] 数 组 名 ; 

声明 数组 时 ,还 没有 创建 数组 ,还 没有 为 数组 元 素 分 配 任 何 内 存 空间 ,因此 ,声明 数组 
后 ,需要 对 数组 实例 化 。 

数组 的 实例 化 有 两 种 方式 : 第 一 种 是 使 用 new 关键 字 进 行 实例 化 ;第 二 种 是 在 声明 数 
组 的 时 候 进行 初始 化 。 

(1) 使 用 new 关键 字 进 行 实例 化 

数组 名 =new 类 型 RER]; 

例如 ， 

int[] a; 

a=new int[4]; 

也 可 以 简写 为 : 


int[] a=new int[4]; 


解释 : 定义 一 个 数组 a, 它 包含 4 个 数组 元 素 , 即 a[0]、a[1]、a[2]、a[3], 每 个 数组 元 素 
的 类 型 都 是 int 类 型 。 

C# 规 定 : 数组 元 素 的 下 标 是 从 0 开始 的 连续 整数 。 

(2) 在 声明 数组 的 时 候 进 行 初始 化 


类 型 [] 数组 名 = {常量 ,… ,常量 }; 


例如 ， 

int[] b= {1, 2, 3, 4, 5}; /人 数组 b 包 含 5 个 元 素 

string c[]= ("one", "two", "three", "four", "five"}; // 数 组 < 包含 5 个 元 素 
2.4.2 多 维 数组 


多 维 数组 和 一 维 数组 有 很 多 相似 的 地 方 , 多 维 数组 有 多 个 下 标 ,声明 二 维 数组 的 语法 
如 下 : 


类 型 [，] 数组 名 ; 


二 维 数组 的 实例 化 和 一 维 数组 相似 ,可 以 使 用 new 关键 字 进 行 实例 化 ,也 可 以 在 声明 
数组 的 时 候 进行 初始 化 。 

(1) 使 用 new 关键 字 进 行 实例 化 

数组 名 =new 类 型 [表达 式 1, 表 达 式 2]; 

C# 规 定 : 数组 元 素 的 下 标 是 从 0 开始 的 连续 整数 。 表 达 式 1 表示 数组 元 素 占 多 少 行 ， 
表达 式 2 表示 每 行 有 多 少 个 数组 元 素 。 

例如 ， 


int[,] a; 
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a-new int[3,2]; 
也 可 以 简写 为 : 
int[,] a=new int [3,2]; 


解释 : 定义 一 个 数组 a, 它 包 含 6 个 数组 元 素 , 即 a[0,0]、a[0,1]、a[1,0]、a[1,1]、 


a[2,0].a[2.1]. 
(2) 在 声明 数组 的 时 候 进 行 初 始 化 
例如 ， 


intL,] b= (00, 1), {2, 3), (6, 9); 
25 程序 流程 控制 


在 通常 情况 下 ,程序 中 的 代码 是 按 顺 序 执行 的 (顺序 结构 ), 若 要 改变 代码 的 执行 顺序 ， 
就 要 使 用 流程 控制 语句 。 
2.5.1 选择 结构 

选择 结构 的 典型 语句 有 让 语句 和 switch 语句 ,它们 都 是 以 特定 的 值 或 表达 式 来 决定 要 
不 要 执行 程序 代码 的 。 

1. if 语句 

if 语句 的 语法 格式 如 下 : 

if (表达 式 ) 语句 1 [else 语句 2] 

当 表达 式 的 值 为 真 时 ,就 执行 “语句 1”, 否 则 执行 “语句 2"。 其 中 ,语句 1”“ 语 句 2” 可 
以 是 任意 一 个 C# 语 句 。 例 如 : 

if (a>b) max=a; else max=b; 

2. if 语句 的 嵌 套 

让 语 句 一 般 用 于 解决 单 分 支 , 双 分 支 问题 ,必要 时 ,也 可 以 解决 多 分 支 问题 。 

if iB] RERUM T: 

if (表达 式 1) 语 句 1 


else if (表达 式 2) 语 句 2 
else if (表达 式 3) 语 句 3 


elsei&] n 


【 例 2-5】 Ait —^- CE 程序, 利用 键盘 输入 一 个 百分制 成 绩 ,要 求 输出 成 绩 等 级 。 
90 分 以 上 输出 'A',80 一 89 分 输出 B',70 一 79 分 输出 'C' ,60 一 69 分 输出 'D',60 分 以 下 输出 它 ',。 
程序 代码 如 下 : 


class Program 
( static void Main (string[] args) 


) 
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System.Console.Write ("请 输入 一 个 成 绩 :"); 

int score= int.Parse (System.Console.ReadLine () ) ; 
if(score»- 90) grade- 'A'; 

else if (score»-80) grade- 'B'; 

else if (score»- 70) grade- ''C'; 

else if (score»- 60) grade- 'D'; 

else grade- 'E'; 

System.Console.WriteLine (" 成 绩 等 级 为 "+ grade) ; 
System.Console.Read() ; 


3. switch 语句 
switch 语句 也 叫做 多 分 支 语句 , 它 可 以 根据 表达 式 的 值 来 决定 执行 哪个 case 块 的 语 
^ij, switch 语句 的 语法 格式 如 下 : 


switch (表达 式 ) 
(case 常量 1: 语句 块 1; 


break; 


case 常量 2: 语句 块 2; 


break; 


case 常量 n: 语句 块 n; 


break; 


[default: 语句 块 n+ 1;break; ] 


) 


首先 计算 表达 式 的 值 , 如 果 表 达 式 的 值 与 某 个 case 块 的 常量 相等 ,就 转 去 执行 该 case 
块 的 语句 , 当 表达 式 的 值 与 任何 case 块 的 常量 都 不 相等 时 ,就 执行 default 中 的 语句 。 


注意 : 


A) switch 后 面 表 达 式 的 类 型 必须 是 整 型 或 字符 型 。 

(2) 在 C# 中 , 当 case 分 支 后面 有 语句 时 ,必须 以 break 语句 结尾 。 

(3) 多 个 不 同 的 case 分 支 可 以 执行 同一 个 语句 块 。 

【 例 2-6】 编写 一 个 C# 程 序 , 要 求 利用 键盘 输入 一 个 月 份 后 ,能 够 在 屏幕 上 显示 出 该 


月 的 天 数 。 


程序 代码 如 下 : 


class Program 


{ static void Main(string[] args) 


t 


int day; 

System.Console.Write (" 请 输入 一 个 月 份 :m); 

int month= int.Parse (System.Console.ReadLine () ) ; 
Switch (month) 

{ Case 1: 


case 3: 
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case 5: 

case 7: 

case 8: 

case 10: 

case 12: day-31; break; 
case 4: 

case 6: 

case 9: 

case 11: day- 30; break; 
case 2: day-28; break; 
default: day-0; break; 

) 


System.Console.WriteLine ("\n{0} 月 份 的 天 数 为 :{1}" month, day) ; 


System.Console.Read (); 


} 


2.5.2 循环 结构 


循环 结构 就 是 将 某 些 程序 语句 重复 执行 多 次 的 一 种 程序 结构 ,这 种 结构 可 以 简化 程序 
的 设计 ,完成 其 他 结构 不 能 完成 的 任务 。C# 中 有 4 种 循环 语句 ,分 别 是 while 语句 、do- 


while 语句 ,for 语句 和 foreach 语句 。 


1. while 语句 
while 语句 的 语法 格式 如 下 : 


while (表达 式 ) 语句 


while 语句 的 执行 过 程 如 图 2-5 所 示 。 
【 例 2-7】 用 while 语句 求 1 一 100 之 间 的 偶数 。 


Class Program 
( static void Main(string[] args) 
{ ints-0; 
int i=2; 
while (i«-100) 
{ ssi; 
i=i+2; 
} 
System.Console.WriteLine ("MX "+ s); 
System.Console.Read() ; 


) 


2. do-while 语句 
do-while 语句 的 语法 格式 如 下 : 


do 


图 2-5 whilei&/] 
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循环 体 语句 
while (表达 式 ); // 注 意 末尾 有 分 号 


do-while 语句 的 执行 过 程 如 图 2-6 所 示 。 
[52-8] 用 do-while 语句 求 1 一 100 之 间 的 偶数 。 


Class Program 
{ static void Main (string[] args) 
{ int s0; 
int i=2; 
do 
{ s95sti; 
i=i+2; 
} 
while (i«-100); 
System.Console.WriteLine (" 和 为 "+ s); 
System.Console.Read() ; 


) 


注意 : while 语句 的 特点 是 , 先 判 断后 执行 ,可 能 一 次 也 不 执行 循环 体 。 而 do-while 语 
句 是 先 执行 后 判断 ,至 少 要 执行 一 次 循环 体 。 


3. for 语句 
for 语句 的 语法 格式 如 下 : 


for (表达 式 1; 表 达 式 2; 表 达 式 3) 循环 体 语句 
for 语句 的 执行 过 程 如 图 2-7 所 示 。 


t 
表达 式 l 


假 


T 


ü 
循环 体 
E 


图 2-6 do-while 语句 图 2-7 for 语 句 


说 明 : 

CD 表达 式 1 常用 于 对 循环 变量 赋 初 值 ;表达 式 2 常用 于 判断 循环 变量 是 否 超出 终 值 ; 
表达 式 3 常用 于 修改 循环 变量 的 值 。 

(2) 表达 式 1 、 表 达 式 2、 表 达 式 3 都 可 以 省 略 ,但 分 号 不 能 省 略 。 例 如 ,for(;;) 语 句 。 

【 例 2-9】 用 for 语句 求 1 一 100 之 间 的 偶数 。 
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程序 代码 如 下 : 


class Program 
{ static void Main (string[] args) 
(  ints-0; 
inti; 
for (i72; i«-100; i+=2) 
s=s+i; 
System.Console.WriteLine ("fly "+ s); 
System.Console.Read() ; 


) 


4. foreach 语句 
foreach 语句 用 于 列举 一 个 数组 或 集合 中 的 所 有 元 素 。foreach 语句 的 语法 格式 如 下 ; 


foreach (类 型 成 员 名 in 数组 名 /集合 名 ) 
{循环 体 } 


对 于 数组 或 集合 中 的 每 一 个 元 素 , 都 重复 执行 循环 体 。 成 员 名 代表 数组 或 集合 中 的 一 
个 元 素 。 
下 面 的 代码 演示 了 foreach 语句 的 用 法 。 


jnt[]a= (3,6,9,12,15,18); 
foreach (int i in a) 
(System.Console.Write (i*",");) 


5. 跳 转 语句 

(1) break 语句 : 终止 并 跳出 循环 。 

(2) continue 语句 : 终止 当前 的 循环 ,重新 开始 一 个 新 的 循环 。 

break 语句 只 能 用 于 switch 语句 中 或 循环 体内 , 当 break 语句 用 于 循环 体内 时 , 常 与 if 
语句 配合 使 用 。continue 语句 只 能 用 于 循环 体内 ,并 常 与 让 语 句 配 合 使 用 。 
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类 是 一 种 抽象 的 数据 类 型 ,是 对 一 类 事物 的 统一 描述 。 在 生活 中 ,通常 把 一 组 具有 相同 
特性 的 事物 归 为 一 类 。 例 如 ,汽车 人、 房子 动物 等 都 是 独立 的 类 ,它们 都 有 各 自 的 特点 。 
汽车 这 个 大 类 可 进一步 分 成 卡车 、 客 车 .小 轿车 等 各 种 小 类 。 将 这 些 思想 应 用 到 编程 技术 中 
就 产生 了 “类 ”的 概念 。 

对 象 可 以 看 做 是 类 中 一 个 具体 的 事物 。 类 是 对 象 共 同 拥有 的 属性 的 描述 ,对 象 是 类 的 
具体 表现 。 例 如 汽车 属于 一 个 类 ,而 具体 到 东风 卡车 、 宝 马 小 车 就 是 对 象 。 

类 (class) 是 C# 类 型 中 最 基础 的 类 型 。 类 是 一 个 数据 结构 ,将 状态 (属性 ) 和 行为 ( 方 
法 ) 封 装 在 一 个 单元 中 。 类 提供 了 用 于 动态 创建 类 实例 的 定义 ,也 就 是 对 象 (object) 。 类 支 
持 继承 (inheritance) 和 多 态 (polymorphism) , 即 派 生 类 能 够 扩展 和 特殊 化 基 类 的 机 制 。 
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2.6.1 类 的 声明 
1. 声明 类 的 基本 格式 


class 类 名 [: 基 类 ] 
{ 成 员 变量 声明 ; 

成 员 函 数 声明 ; 
} 


定义 一 个 类 时 ,车 省 略 基 类 , 则 默认 从 Object 类 继承 而 来 ,C# 中 所 有 的 类 都 直接 或 间 
接 继承 Object 类 。 

下 列 代码 演示 了 类 的 声明 : 

class A 


{ 
public int a; // 声 明成 员 变量 
private int b; 
protected int c; 


public void setA() // 声 明成 员 函 数 
{ 
al; 


2. 类 的 成 员 

类 的 成 员 有 两 类 : MR E EAU D ER 

成 员 变量 ,又 称 为 属性 ,其 声明 格式 如 下 : 
[public/protected/private] [static] 类 型 变量 名 ; 
成 员 函 数 ,又 称 为 方法 ,其 声明 格式 如 下 : 


public/protected/private] [static] 类 型 函数 名 ( 形 参 表 ) 

t ) 

类 成 员 的 访问 权限 有 3 种 ,说明 如 下 : 

(1) private; 私有 成 员 , 只 能 被 自身 类 的 成 员 函 数 访问 , 当 一 个 成 员 没 有 指定 访问 说 明 
符 时 ,默认 为 private。 

(2) protected; 受 保护 成 员 , 只 能 被 自身 类 和 派生 类 的 成 员 函 数 访问 。 

(3) public; 公有 成 员 , 可 以 被 任意 命名 空间 中 的 类 的 成 员 函 数 访问 。 


2.6.2 对 象 的 创建 和 回收 


C# 中 有 两 个 特殊 的 函数 : 构造 函数 和 析 构 函数 ,分 别 用 于 创建 和 回收 对 象 。 构 造 函数 
是 当 类 被 实例 化 时 首先 执行 的 函数 ; 析 构 函数 是 当 从 内 存 中 删除 实例 对 象 时 执行 的 函数 。 
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在 一 个 对 象 的 生命 周期 中 ,都 会 执行 构造 函数 和 析 构 函数 。 下 面 分 别 介 绍 构造 函数 和 析 构 
函数 的 定义 及 其 使 用 方法 。 


1. 构造 函数 
构造 函数 的 声明 格式 如 下 : 


public 构造 函数 名 ( 形 参 表 ) 
{ 函数 体 } 


注意 : 

(D 构造 函数 名 必须 与 类 名 相同 。 

(2) 定义 构造 函数 时 ,不 能 指定 数据 类 型 。 

(3) 一 个 类 可 以 定义 多 个 参数 不 同 的 构造 函数 。 

(4) 每 个 类 至 少 有 一 个 构造 函数 , 若 在 类 声明 中 没有 显 式 定义 构造 函数 , 则 编译 系统 会 
自动 提供 一 个 默认 的 构造 函数 , 即 ; 

public 构造 函数 名 ( ) 

{} 


(5) 构造 函数 在 创建 对 象 时 被 自动 调用 。 
【 例 2-10】 构造 函数 的 用 法 示例 。 


class Student 

( public string no, name; 
public Student (string xh, string xm) 
(  no-xh; 


public static void Main () 

{ Student stu-new Student ("01", " 张 三 "); 
System.Console.WriteLine ("学 号 :{0}, 姓 名 :{1}",，stu.no, stu.name); 
System.Console.Read (); 


} 


2. 析 构 函数 
析 构 函数 的 声明 格式 如 下 : 


~ 类 名 () 
{ 函数 体 } 


CD 析 构 函数 的 函数 名 是 在 类 名 前 加 ~ , 且 不 能 拥有 访问 修饰 符 。 

(2) 一 个 类 最 多 只 能 有 一 个 析 构 函数 , 析 构 函数 不 带 形 参 。 

G) 析 构 函数 在 释放 对 和 象 时 被 自动 调用 ,常用 来 处 理 类 用 完 后 的 收尾 工作 。 
下 面 的 代码 演示 了 析 构 函数 的 用 法 : 
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class MyClass 
{ 
~MyClass() 
1 
/人 收尾 工作 


p 

3. 对 象 的 创建 

对 象 的 创建 格式 如 下 : 

类 名 对 象 名 =new 构 造 函 数 名 ( 实 参 表 ) 7 


创建 对 象 ,意味 着 为 对 象 的 非 静态 属性 分 配 存储 空间 ,而 静态 属性 被 分 配 在 一 个 公共 区 
域 中 ,由 该 类 的 所 有 对 象 共享 。 
【 例 2-11】 对 象 的 创建 示例 。 


1. class Student 
2.(  inta-20; 


3 static int b- 200; 

4 public static void Main() 

5 { Student stul-new Student () ; 

6. Student stu2- new Student () ; 

7 stul.a=10; 

8 b-100; 

9 System.Console.WriteLine ("stu2.a- "+ stu2.a) ; 
10. System.Console.WriteLine ("Student .b= "+ Student .b) ; 
1i. System.Console.Read () ; 

12. ) 

13.) 


程序 说 明 : 第 5 行 和 第 6 行 创 建 了 两 个 对 象 , 即 stul 和 stu2 ,它们 有 各 自 的 a 属性 值 ， 
但 b 属性 值 为 两 个 对 象 所 共享 ,所 以 程序 运行 结果 为 : 


stu2.a=20 
Student.b= 100 


注意 : 
(D 引用 对 象 的 非 静态 成 员 ， 


对 象 名 .属性 名 
对 象 名 .方法 名 ( 实 参 表 ) 


D 引用 对 象 的 静态 成 员 : 


类 名 .属性 名 
类 名 .方法 名 ( 实 参 表 ) 
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静态 成 员 的 左边 只 能 是 类 名 。 

(3) 静态 方法 只 能 直接 调用 自身 类 的 静态 成 员 ; 非 静态 方法 可 以 直接 调用 自身 类 的 所 
有 成 员 。 

【 例 2-12】 静态 成 员 的 用 法 示例 。 


class First 
{ static int id-3; 

int x-30; 

public static void Main (String[] args) 

{ First c=new First(); 
System.Console.WriteLine (id); 
System.Console.WriteLine (c.x) ; 
System.Console.WriteLine (First.id); 


) 


2.6.3 继承 和 多 态 
继承 和 多 态 是 面向 对 象 程序 设计 的 两 个 重要 特征 。 


1. 继承 

C# 只 支持 单 继承 , 即 一 个 子 类 只 能 有 一 个 父 类 。 子 类 可 以 继承 父 类 的 所 有 非 private 
成 员 ( 构 造 函 数 和 析 构 函数 也 不 能 被 继承 ) ,还 可 以 定义 自己 的 新 成 员 。 

继承 性 使 得 软件 模块 可 以 被 最 大 限度 地 复 用 ,并 且 编 程 人 员 还 可 以 对 他 人 或 自己 以 前 
的 模块 进行 扩充 ,而 不 需要 修改 原来 的 源 代码 ,大 大 提高 了 软件 的 开发 效率 。 

继承 的 语法 格式 如 下 : 


class 类 名 : 基 类 
{ 类 的 成 员 变量 或 成 员 函 数 } 


[B 2-13] 子 类 继承 父 类 的 示例 。 


using System; 
public class Parent 
t 
public Parent( ) 
t 
Console.WriteLine(" 父 类 构造 函数 "); 
public void print( ) 
{ 
Console.WriteLine ("输出 父 类 ") ; 
$ 
} 
public class Child : Parent 
{ 
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public child( ) 
t 
Console.WriteLine (" 子 类 构造 函数 ") ; 
) 
public static void Main( ) 
t 
Child x-new Child() ; 


x.print() ; 


) 


程序 说 明 : C# 规 定 ,创建 一 个 派生 类 的 对 象 时 ,要 先 调用 基 类 的 无 参 构造 函数 ,再 调用 
派生 类 的 构造 函数 ,所 以 程序 的 运行 结果 为 ; 

父 类 构造 函数 

子 类 构造 函数 

输出 父 类 


2. 多 态 

同一 操作 作用 于 不 同 的 对 象 , 可 以 有 不 同 的 解释 ,产生 不 同 的 执行 结果 ,这 就 是 多 态 性 。 

例如 ,把 学 生 召 集 起 来 ,向 他 们 发 出 一 个 指令 (类 的 方法 ):“ 去 训练 1”, 不 同 的 学 生 会 采 
用 不 同 的 训练 方法 ,有 的 打 篮 球 , 有 的 踢 足 球 , 有 的 游泳 。 对 父 类 而 言 ,只 需要 告诉 它 的 子 类 
“去 训练 ” 即 可 。 在 面向 对 象 的 思想 中 ,这 称 为 多 态 。 

现在 定义 一 个 抽象 类 Player ,其 包含 一 个 抽象 方法 ,注意 此 方法 没有 实现 任何 功能 ,如 
BER: 


// 一 个 运动 员 类 
public abstract class Player 
{ 
public abstract void Train () 
) 


下 面 的 代码 定义 了 3 个 类 ,都 继承 自 上 面 的 抽象 类 ,并 且 都 实现 了 方法 Traino ,不 同 
的 方法 输出 不 同 的 内 容 , 这 就 是 多 态 性 。 


// 篮 球 运 动员 
public class Basketball:Player 
{ 

public override void train() 

t 

Console.WriteLine ("运动 员 在 训练 篮球 !"); 

} 
// 足 球 运动 员 
public class Football:Player 
t 
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public override void train () 
t 
Console.WriteLine ("运动 员 在 训练 足球 !"); 
} 
// 游 泳 运动 员 
public class Swim:Player 
t 
public override void train() 
{ 
Console.WriteLine ("运动 员 在 训练 游泳 1"); 
} 


27 异常 处 理 


异常 是 指 程序 在 运行 期 间 遇 到 的 任何 错误 情况 或 意外 行为 。 例 如 ,数组 下 标 越界 ,除数 
为 0 等 。C# 提 供 了 一 种 异常 处 理 机 制 , 这 种 机 制 可 以 减轻 程序 员 的 负担 ,使 得 程序 更 清 
晰 、 更 健壮 ,容错 性 更 强 。 


2.7.1 异常 的 定义 


C# 把 异常 看 做 一 个 类 。 当 C# 程 序 中 的 某 一 条 语句 出 现 异常 时 ,系统 就 自动 创建 一 个 
异常 对 象 ,并 转 去 执行 相应 的 异常 处 理 代码 。 异 常 处 理 代 码 是 一 段 可 执行 的 程序 代码 ,可 以 
由 用 户 自己 编写 ,也 可 以 采用 系统 提供 的 异常 处 理 代码 。 

【 例 2-14】 系统 提供 的 异常 处 理 代 码 示 例 。 


Class Program 
{ 
static void Main (string[] args) 
{ 
int a, b=0; 
a=2/b; // 此 处 有 异常 
System.Console.WriteLine ("\ta= "+a); 
System.Console.Read() ; 


} 


运行 结果 如 图 2-8 所 示 。 REESENED 
Exception 是 所 有 异常 类 的 基 类 。 下 面 介绍 图 2.8 BAR 
几 种 常见 的 异常 类 。 


OD 算术 异常 : ArithmeticException、DivideByZeroException。 
(2) 空 对 象 异常 : NullReferenceException, 例 如 : 


int[] a-null; 
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System.Console.WriteLine (a.Length); 
(3) 数组 下 标 越界 异常 : IndexOutOfRangeException ,例如 ; 


int[]a-new int[10]; 


a[10]=0; 


2.7.2 try-catch 语句 


C# 语 言 允许 用 户 自己 编写 异常 处 理 代 码 , 这 就 要 用 到 try-catch 语句 。 
try-catch 语句 的 格式 如 下 : 


try{ 程 序 块 1} 
catch (异常 类 1 e) 
{异常 处 理 代码 } 
catch (异常 类 2 e) 
{ 异 常 处 理 代码 } 


当 try 子 句 产生 一 个 异常 时 ,就 抛 出 一 个 异常 对 象 ,接着 检查 各 个 catch 子 句 , 若 某 个 
catch 子 句 与 异常 对 象 相 匹配 ,就 执行 相应 的 异常 处 理 代 码 。 若 没有 一 个 catch 子 句 与 异常 
对 象 匹配 , 则 转 去 执行 默认 的 异常 处 理 代码 。 

【 例 2-15] 采用 try-catch 语句 编写 异常 处 理 代码 示例 。 


class test 
{ public static void Main() 
{ 
try 
{ 
int a, b=0; 
a=2/b; 
System.Console.Write ("a="+a); 
} 
catch (ArithmeticException) 
{ 
System.Console.WriteLine ("0 不 能 作 除 数 !"); 
} 
System.Console.ReadLine (); 


28 命名 空间 


C# 的 命名 空间 相当 于 Java 的 包 名 ,一 个 命名 空间 可 以 包含 多 个 类 和 多 个 子 命名 空间 。 
使 用 命名 空间 可 以 避免 命名 冲突 。 
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1. 声明 命名 空间 


namespace 命名 空间 名 [. 命 名 空间 ] 
B 


举例 1. 


namespace N1.N2 

{ public class A( ) 
public class B( } 

) 


举例 2: 


namespace N1 
( public class A( ) 
namespace N2 
{ public class B( ) ) 
) 


注意 : 

(1) 声明 命名 空间 时 ,不 必 创 建文 件 夹 。 

(2) 每 一 个 . cs 文件 都 存在 一 个 全 局 命名 空间 ,用 户 声 明 的 命名 空间 只 是 全 局 命名 空间 
的 一 个 成 员 。 

2. 使 用 命名 空间 

using 命名 空间 [. 命 名 空间 ]; 

例如 


using Nl; 


using Nl.N2; 

iE. 

(1) using 语句 只 导入 最 底层 的 命名 空间 中 的 类 ,不 导入 嵌 套 的 命名 空间 。 
(2) using 语句 必须 放 在 每 一 层 命名 空间 的 首部 。 

【 例 2-16】 using 语句 的 用 法 示例 。 


1. namespace N1.N2 


2. { 

3 classA { } 

4. classB { } 

S. p 

6. namespace N3 

7. ( 

8. using Nl.N2; 
9. ClassC: A 

10. 1 


Ti. public static void Main() 


12. 
33. 
14. 
15. 
16. 
17. ) 
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t 
System.Console.WriteLine ("OK"); 
System.Console.ReadLine () 7 
} 
} 


程序 说 明 : 第 8 行 using 语句 要 放 在 命名 空间 N3 的 第 1 £5 , 若 省 略 第 8 行 , 则 第 9 行 要 


改 成 class 


Cè NI. NZ. A, 


3. 命名 空间 System 的 内 容 
System 包含 C 间 语言 的 核心 类 ,下 面 介绍 System 中 的 常见 类 。 
(OD .NET 类 型 : 每 一 种 . NET 类 型 都 对 应 一 种 C# 类 型 , 见 表 2-12。 


表 2-12 .NET 类 型 


. NET 类 型 C# 类 型 .NET 类 型 C# 类 型 . NET 类 型 C# 类 型 
Byte byte Int64 long Boolean bool 
SByte sbyte Single float String string 
Int16 short Double double Object object 
Int32 int Char char 


在 C# 中 ,每 种 类 型 都 包含 各 种 方法 ,例如 : 
System.Double.Parse("31.4") 


(2) Console 类 : 控制 台 是 一 个 用 来 提供 字符 模式 的 1/0 接口 , 它 的 界面 类 似 MS-DOS 
模式 。Console 类 的 常用 方法 : Console. ReadLine() 表 示 从 标准 输入 流 中 读 取 一 行 字 符 ; 
Console. WriteLine() 将 指定 的 数据 写 和 人 标准 输出 流 中 。 

(3) Convert 类 : 用 于 数据 类 型 的 转换 ,常用 方法 如 下 。 

Convert, ToSbyte(x) : 将 任意 型 x 转换 为 sbyte 型 。 

Convert, ToInt16(x): 将 任意 型 x 转换 为 short 型 。 

Convert. Tolnt32 (x): 将 任意 型 x 转换 为 int 型 ,x 在 int. Parse(x) 中 ,x 为 String 型 。 

Convert. ToInt64 G0 ; 将 任意 型 x 转换 为 long 型 。 

Convert. ToSingle(x) : 将 任意 型 x 转换 为 float 型 。 

Convert. ToDouble(x) : 将 任意 型 x 转换 为 double 型 。 

Convert. ToBoolean(x) : 将 整 型 浮 点 型 数据 x 转换 为 bool 型 。 

Convert. ToCharGO : 将 整 型 x 转换 为 char 型 。 

Convert. ToDateTime(x) ; 将 具有 日 期 时 间 意 义 的 字符 串 x 转换 为 DateTime 型 。 


实 训 1 


29 项 目 实 训 
创建 一 个 控制 台 应 用 程序 


实 训 目的 
(1) 掌握 创建 一 个 控制 台 应 用 程序 的 方法 。 
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(2) 掌握 解决 方案 、 项 目 .C# 文 件 三 者 的 关系 。 


实 训 要 求 
CD. 创建 一 个 解决 方案 sx06 ,在 其 中 创建 一 个 项 目 “2-1”。 
(2) 在 项 目 中 创建 C# 程 序 ,在 屏幕 上 输出 0 一 100 之 间 能 被 5 整除 的 数 。 


实 训 2 数组 和 循环 谋 僚 


实 训 目 的 
(OD 掌握 循环 语句 的 嵌 套 使 用 方法 。 
(2) 了 解 选择 排序 的 方法 。 


实 训 要 求 

CD 在 解决 方案 sx06 中 添加 项 目 “2-2”。 

(2) 在 项 目 中 创建 C# 程序 ,从 键盘 上 任意 输入 10 个 数 ,然后 将 它们 按 由 小 到 大 的 顺 
序 输出 。 


实 训 提示 
(OD 参考 代码 : 


using System; 
Class Program 
t 
static void Main (string[] args) 
t 
double[] a=new double[10]; 
Console.WriteLine ("请 输入 10 4-3 :") ; 
ánE 3, 3; 
double t; 
for(i-0; i«10; i++) 
a[i]-double.Parse (Console.ReadLine ()); 
// 选 择 排序 
for(i-0; i«9; i++) 
{ 
for(j=i+1; j<10; j++) 
if (a[i]>a[j]) 
{t=a[i]; a[il=a0D]; alj]=t;} 
} 
Console.WriteLine ("排序 后 :"); 
for(i=0; i<10; i++) 
Console.Write ("(0)", a[i]); 
Console.Read(); 


(2) 将 项 目 “2-2? 设 为 启动 项 目 。 
实 训 3 ”类 和 对 象 的 创建 


实 训 目的 
(1) 掌握 类 的 定义 。 
(2) 掌握 对 象 的 创建 。 


实 训 要 求 
(1) 在 解决 方案 sx06 中 添加 项 目 *2-3”。 
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(2) 在 项 目 中 创建 C# 程 序 ,定义 一 个 表示 盒子 的 类 Box, 现 实 世界 中 的 盒子 具有 宽度 、 
高 度 和 深度 等 属性 ,定义 构造 函数 对 盒子 的 属性 进行 初始 化 ;定义 一 个 方法 showBox() 用 
于 显示 盒子 的 体积 ;定义 一 个 Main() 函 数 让 用 户 输入 盒子 的 宽度 、 高 度 和 深度 。 


实 训 提示 


Class Box 
{ 
double w,h,d; 
public Box (double x,double y,double z) 
{ 
w-x;h-y;d-z; 
) 
void showBox () 
{ 
double v-w* hx d; 
System.Console.WriteLine (" 盒 子 的 体积 为 : "+v); 
) 
static void Main (string[] args) 
{ 


Console.WriteLine (" 请 输入 盒子 的 宽度 ,高 度 和 深度 :"); 


double w= double.Parse (Console.ReadLine|()); 
double h= double.Parse (Console.ReadLine|()) ; 
double d= double.Parse (Console.ReadLine|()) ; 
Box box- new Box (w,h,d) ; 

box.showBox () ; 

Console.Read(); 


思考 与 练习 


一 、 填空 题 


1. 在 ASP. NET 开发 环境 中 ,用 C# 编 写 的 代码 存放 在 以 为 扩展 名 的 文 


iin. 
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2. 执行 下 列 C# 语 句 : int x 二 100;y 二 十 十 x; 则 变量 x= ,y= 

3. 在 do-while 语句 中 ,循环 体 至 少 执行 次 。 

4. 构造 函数 在 时 被 自动 调用 ; 析 构 函数 在 时 被 自动 调用 。 
5. 在 C# 程 序 中 可 使 用 try-catch 机 制 来 处 理 程序 出 现 的 s 

二 、 编 程 题 


l. 编写 控制 台 程 序 , 使 用 键盘 输入 10 个 整数 ,输出 其 中 的 最 大 数 与 最 小 数 。 

2. 编写 控制 台 程序 ,计算 从 1949 年 到 2010 年 共有 多 少 个 图 年 ,并 输出 各 图 年 的 年 份 。 

3. 编写 控制 台 程序 ,添加 一 个 小 汽车 类 Car, 它 包含 3 个 属性 : 颜色 (Color)、 车 名 
(Name) .产地 (ProductPlace) ,1 个 方法 RunO ,用 于 输出 “我 是 X X 车 ,颜色 是 XX ,产地 在 
XX1” 信 息 。 要 求 : 给 Car 类 添加 一 个 有 参数 的 构造 函数 ,在 构造 函数 内 给 属性 赋值 ,通过 
这 个 有 参数 的 构造 函数 创建 对 象 ,并 调用 Run( ) 方 法 。 


gos 
服务 器 控件 


ASP. NET 之 所 以 方便 和 强大 ,关键 在 于 它 提供 了 一 组 功能 强大 的 ASP. NET 服务 器 
控件 。 服 务 器 控件 包括 4 大 类 : HTML 控件 ,Web 控件 、 验 证 控件 ,用户 控 件 。 

本 章 首先 介绍 ASP. NET 文件 的 组 成 ,接着 重点 介绍 HTML 控件 、Web 控件 、 验 证 控 
件 3 类 服务 器 控件 及 其 用 法 ,最 后 简单 介绍 用 户 控件 的 开发 。 


AREE 


* 了解 ASP. NET 文件 的 结构 
。 掌握 HTML 控件 的 应 用 

* 掌握 Web 控件 的 应 用 

。 掌握 验证 控件 的 应 用 

。 了 解 用 户 控件 的 开发 


3.1 ASP. NET 文件 


ASP 5j ASP. NET 是 目前 较为 流行 的 两 种 基于 Internet 的 开发 工具 ,ASP. NET 是 在 
ASP 基础 上 推出 的 ,但 它 采 用 全 新 的 技术 架构 ,使 得 ASP. NET 具有 更 好 的 性 能 ,具有 更 好 
的 语言 特性 ,更 易于 开发 ,更 强大 的 IDE 支持 ,更 易于 配置 管理 ,更 易于 扩展 ,更 加 安全 。 

ASP 只 支持 解释 型 语言 ,包括 VBScript 和 JavaScript. 当 用 户 发 出 请 求 后 ,无 论 是 第 几 
次 ,ASP 的 页 面 都 被 动态 解释 执行 。 

ASP. NET 支持 编译 型 语言 ,包括 Visual Basi. NET, C £, Visual C ++. NET, 
J]#.NET, 同 时 支持 面向 对 象 程序 设计 ,包括 封装 、 继 承 、 多 态 性 等 特点 。 从 理论 上 讲 ， 
ASP. NET 页 面 第 一 次 执行 时 会 比较 慢 , 因 为 要 编译 页 面 ,但 第 二 次 及 之 后 执行 时 就 会 比 实 
现 同样 功能 的 ASP 页 面 快 ,大 约 快 2.5 fii. 


3.1.1 ASP. NET 文件 的 构成 


ASP. NET 文件 由 用 户 界面 与 实现 逻辑 两 部 分 组 成 。 
用 户 界 面 即 . aspx 页 面 , 包 含 如 下 元 素 。 
(OD 指令 : WE Q5 A zs 


(2) £include 命令 ; 


dd 
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(3) HTML 标记 和 文本 ; 

(4) 服务 器 控件 : 包括 HTML 控件 、Web 控件 、 验 证 控件 ,用户 控件 ; 

(5) JavaScript 脚本 : JE <script language— "JavaScript" 7 5 </script> Z [8] . 

实现 逻辑 指 用 于 处 理 . aspx 页 面 的 代码 , 它 负责 数据 的 交互 ,处理 。 实 现 逻辑 一 般 放 
在 . cs 文件 中 ,该 文件 又 称 为 代码 隐藏 文件 。 


1. 指令 
指令 通常 放 在 文件 的 开头 ,指令 格式 如 下 : 


<s@ 指 令 属性 = 值 属性 = 值 …%> 
常见 的 指令 有 Page, Control, Import, Register 等 ,例如 : 


«$6 Page Language- "Cft " CodeFile- "Image.aspx.cs" Inherits- "Web Image"$» 


2. £include 命令 
& include 命令 用 来 将 指定 文件 的 内 容 插 入 到 . aspx 页 面 中 ,格式 如 下 ; 


<!--#include file- "Xf "--» 


3.1.2 ASP. NET 页面 的 执行 过 程 


了 解 Web 页 面 的 处 理 过 程 很 重要 ,这 样 就 可 对 代码 进行 细致 的 优化 ,提高 代码 的 执行 
效率 。 

使 用 过 ASP 技术 的 人 应 该 会 知道 ,ASP 是 线性 处 理 模型 , 即 按 从 上 到 下 的 顺序 进行 处 
理 。 而 ASP. NET 通过 模拟 事件 驱动 模型 的 行为 代替 ASP 的 线性 处 理 模 型 。ASP. NET 
提供 页 框架 , 隐 式 地 为 用 户 建立 事件 和 事件 处 理 程序 的 关联 。 利 用 该 页 框架 ,可 以 很 容易 地 
创建 响应 用 户 操作 的 用 户 界面 。 

ASP. NET 页 面 的 执行 一 般 要 经 过 下 面 几 个 步骤 。 

(1) ASP.NET 页 面 初始 化 ,触发 Page_Init 事件 ,并 还 原 该 页 和 空间 视图 状态 。 

(2) 用 户 代码 初始 化 ,触发 Page_Load 事件 ,在 这 个 阶段 可 以 使 用 Page. IsPostBack 属 
性 检查 页 面 是 否 是 第 一 次 载 和 人 。 

(3) 事件 处 理 , 触 发 程序 开发 者 定义 的 事件 。 例 如 单 击 按钮 ,提交 表单 。 

(4) 清除 阶段 ,调用 Page Unload 事件 ,将 该 页 面 印 载 ,执行 最 后 的 清除 工作 ,例如 关闭 
文件 .关闭 数据 库 、 印 载 对 象 。 


3.1.3 ”服务 器 控件 概述 
服务 器 控件 包括 HTML 控件 .Web 控件 、 验 证 控件 和 用 户 控件 。 


1. 服务 器 控件 的 通用 属性 

(D) EnableViewState- true/false: 设置 服务 器 控件 能 否 维持 视图 状态 ,默认 为 true. 

当 访 问 服务 器 上 的 一 个 网 页 时 ,服务 器 将 网 页 内 所 有 服务 器 控件 的 属性 值 保存 起 来 , 直 
到 访问 另 一 个 网 页 为 止 ,这 种 情况 称 为 视图 状态 。 

(2) 1d 二"…"; 设置 服务 器 控件 的 标识 名 称 。 
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(3) Visible—true/false: 设置 服务 器 控件 是 否 可 见 ,默认 为 trues 


2. 服务 器 控件 的 通用 方法 
(1) DataBind(): 将 服务 器 控件 连接 到 数据 源 中 。 
(2) FindControl(id) : 在 容器 控件 中 搜索 标识 为 id 的 控件 。 


32 HL 控件 


HTML 控件 与 HTML 标记 相似 ,几乎 与 HTML 标记 有 一 对 一 的 关系 ,差别 在 于 
HTML 控件 的 功能 较 强 , 同 时 它 是 在 服务 器 端 执行 的 对 象 。 将 HTML 标记 转换 为 HTML 
控件 ,只 要 在 标记 中 加 入 runat= server 属性 ,并 将 name 属性 改 为 id 属性 即 可 。 例 如 : 


HIML 标 记 : «input name= "Textl" type="text" value- "汕头 "/> 
HIML 控 件 : «input id- "Textl" type="text" value- "汕头 " runat= "server"/> 


HTML 控件 位 于 System. Web. UI. HtmlControls 命名 空间 中 。 


3.2.1 HTML 控件 的 通用 属性 


1. HTML 控件 的 通用 属性 
(1) Disabled = true/false; 决定 文本 型 或 按钮 型 的 HTML 控件 是 否 可 用 ,默认 为 


false。 

(2) Style; 样式 表 集合 ,存放 指定 控件 的 样式 表 中 的 属性 值 。 

控件 名 .style.add(" 属 性 名 ", 属 性 值 ) 
等 价 于 

控件 名 .style[" 属 性 名 "]= 属 性 值 

注意 ; 凡是 样式 表 中 的 属性 必须 放 在 Style 集合 中 ,例如 ,设置 文本 框 Textl 的 前 景色 
为 红色 ,C# 语 自如 下 : 

Text1.Style["color"]= "red"; 

(3) TagName: 返回 HTML 控件 的 标记 名 称 。 


2. HTML 控件 的 分 类 

(1) HTML 输入 控件 : 控件 声明 中 包含 input 的 HTML 控件 。 如 HtmlInputButton、 
HtmlInputText。 

(2 HTML 容器 控件 : 包含 开始 标记 与 结束 标记 的 HTML 控件 。 如 HtmlSelect, 
HtmlTable。 


3. HTML 输入 控件 的 通用 属性 
Value="…" : 设置 HTML 输入 控件 的 值 。 


4. HTML 容器 控件 的 通用 属性 
(1) InnerHtml 一 "…": 设置 开始 标记 与 结束 标记 之 间 的 文本 ,文本 中 可 包含 HTML 
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标记 。 

(2) InnerText="…": 设置 开始 标记 与 结束 标记 之 间 的 文本 ,文本 中 不 能 包含 HTML 
标记 。 
3.2.2 各 种 HTML 控件 简介 


1. HtmlForm 控件 
表单 控件 (HtmlForm) 又 称 为 窗 体 控件 ,是 设计 动态 网 页 一 个 相当 重要 的 组 件 ,其 声明 
格式 如 下 : 


«form id="…" runat="server" method- "get/post" action="…"> 
其 他 控件 


</form> 


一 个 . aspx 网 页 有 且 只 有 一 个 HtmlForm 控件 ,所 有 的 服务 器 控件 必须 放 在 
HtmlForm 控件 中 。 在 HtmlForm 控件 中 ,action 属性 可 以 省 略 , 若 要 自行 指定 ,也 只 能 指 
向 当前 网 页 。 

2. HtmllnputButton 控件 

HtmlInputButton 控件 分 为 普通 按钮 .提交 按钮 和 重 置 按钮 ,其 对 应 的 HTML 标记 为 
<input type— "button" , input type 王 "submit" , input type= "reset">, 

HTML 控件 的 单 击 事件 为 OnServerClick, Web 控件 的 单 击 事件 为 OnClick。 重 置 按 
钮 不 支持 OnServerClick 事件 。 

服务 器 控件 的 事件 可 产生 于 客户 端 ,也 可 产生 于 服务 器 端 ,但 都 在 服务 器 端 处 理 。 例 
如 , 单 击 事件 产生 于 客户 端 。 

【 例 3-1】 在 站 点 中 添加 一 个 名 称 为 HtmlInputButton. aspx 的 网 页 ,每 次 加 载 网 页 时 
都 会 显示 系统 时 间 , 当 单 击 “ 提 交 ” 按 钮 时 ,将 在 文本 框 中 显示 “提交 ”, 单 击 “ 确 定 ” 按 钮 时 ,将 
在 文本 框 中 显示 “确定 "。 其 设计 界面 运行 界面 如 图 3-1、 图 3-2 所 示 。 


1 17:18:29 1 

MESES Ne Gu ct dnn 4 1 IJ 
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图 3-1 例 3-1 设计 界面 图 3-2 例 3-1 运行 界面 


HtmlInputButton. aspx. cs 文件 的 程序 代码 如 下 : 


protected void Page Load(object sender, EventArgs e) 
{ 
Response.Write (System.DateTime.Now.ToLongTimeString|()); 


) 
protected void Submitl ServerClick (object sender, EventArgs e) 
t 

Text1l.Value- "提交 "; 
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} 
protected void Button2 ServerClick (object sender, EventArgs e) 
t 
Text1.Value= "E "; 
} 


不 管 哪 类 服务 器 控件 ,只 要 存在 OnServerClick =" PR Zi 44 "a OnClick =" R 2c " , D] 
单 击 控件 时 ,会 完成 如 下 4 个 操作 。 

(1) 调用 本 页 面 的 用 户 界面 部 分 。 

(2) 将 客户 端 各 控件 的 主要 属性 值 (Value、Text、Checked、PostFile) 上 传 到 服务 器 。 

(3) 调用 Page_Load() 函 数 。 

(4) 调用 指定 的 函数 。 


3. HtmlinputText 控件 

HtmlInputText 控件 称 为 文本 框 ,对 应 的 HTML 标记 为 过 input type= "Text" >, W H 
属性 和 事件 如 下 : 

(D MaxLength—n: 设置 最 多 可 以 输入 的 字符 数 。 

(2) Size-ni 设置 文本 框 的 宽度 ,单位 为 字符 数 。 

(3) OnServerChange 二 "函数 名 ": 当 服务 器 检查 到 文本 框 中 的 Value 值 发 生变 化 后 ， 
就 会 触发 该 事件 。 

【 例 3-2】 在 站 点 中 添加 一 个 名 称 为 HtmlInputText. aspx 的 网 页 , 当 用 户 在 文本 框 中 
输入 数据 后 单 击 “确定 ”按钮 时 ,会 在 文本 框 下 方 显示 相关 信息 ，; 
若 用 户 向 文本 框 中 再 输入 相同 的 数据 并 单 击 “ 确 定 ” 按 钮 时 , 则 不 | 
会 显示 任何 信息 。 运 行 界面 如 图 3-3 所 示 。 

CD 用 户 界面 的 HTML 代码 如 下 : 


«form id- "forml" runat- "server"> 
< input type-" Text" id-" T1" runat="server" onserverchange =" Changetext" style= 
"width: 133px"> 
«input id- "Submitl" type- "Submit" runat="server" value= "确定 "> &nbsp; «br» «br» 
«span runat="server" id="Spanl">< /span> 
</form> 


(2) .cs 文件 的 代码 如 下 : 


protected void Page Load(object sender, EventArgs e) 
t 
Spanl.EnableViewState- false; 


) 
protected void Changetext (object sender, EventArgs e) 
{ 
Spanl.InnerText=" 文 本 框 的 内 容 变 成 <"+T1.Valuet ">"; 


dL 
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4. HtmlinputHidden 控件 

HtmlInputHidden 控件 称 为 隐藏 框 ,对 应 的 HTML 标记 为 <input type= "hidden". 
常用 事件 如 下 : 

OnServerChange 二 "函数 名 ": 当 服务 器 检查 到 隐藏 框 的 Value 值 发 生变 化 后 ,就 会 触 
发 该 事件 。 

5. HtmllnputRadioButton 控件 

HtmlInputRadioButton 控件 称 为 单 选 按钮 ,对 应 的 HTML 标记 为 过 input type = 
"radio", 

常用 属性 和 事件 如 下 : 

(1) Checked= true/false: 设置 单 选 按钮 的 选中 状态 , 若 为 true 则 表示 选中 。 

(2) Name 一 "组 名 称 "。 

(3) OnServerChange 二 "函数 名 "， 当 服 务 器 检查 到 单 选 按钮 的 Checked 值 发 生变 化 
后 ,就 会 触发 该 事件 。 . 

[5i 33] 在 站 点 中 添加 一 个 名 称 为 Htmllnputr |o SERERBAAES | 
RadioButton. aspx 的 网 页 , 当 用 户 从 单 选 按钮 组 中 选中 最 喜欢 的 oss osx ons 区 | 
水 果 并 单 击 “ 确 定 ” 按 钮 时 ,将 会 在 下 方 以 红色 字体 显示 水 果 的 | RA i 
名 称 , 运 行 界面 如 图 3-4 所 示 。 

(1) 各 控件 的 属性 和 事件 设置 见 表 3-1. 


表 3-1 例 3-3 控件 的 属性 和 事件 设置 


3-4 例 3-3 运行 界面 


控件 类 型 ID 属性 和 事件 设置 

单 选 按钮 Fruitl Value— "Ag" Name- "Fruit" 

单 选 按钮 Fruit2 Value— "4E" Name= "Fruit" 

单 选 按钮 Fruit3 Value 一 "凤梨 ”Name 一 "Fruit" 

提交 按钮 Submitl Value 二 "确定 " OnServerClick 一 "showFruit" 
Span 控件 Spanl Style= "Color: Red" 


(2) .cs 文件 的 代码 如 下 : 


protected void showFruit (object sender, EventArgs e) 

t 
if(Fruitl.Checked-- true)Spanl.InnerText- Fruitl.Value; 
if(Fruit2.Checked-- true) Spanl.InnerText- Fruit2.Value; 
if (Fruit3.Checked-- true) Spanl.InnerText- Fruit3.Value; 

) 


6. HtmllnputCheckBox 控件 

HtmlInputCheckBox 控件 称 为 复 选 框 , 对 应 的 HTML bid < input type = 
"checkbox", 

常用 属性 和 事件 如 下 : 
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(D) Checked= true/false: 设置 单 选 按钮 的 选中 状态 , 若 为 true 则 表示 选中 。 

(2) OnServerChange— " KAA": 当 服务 器 检查 到 复 选 框 的 Checked 值 发 生变 化 后 ， 
就 会 触发 该 事件 。 

【 例 3-4】 在 站 点 中 添加 一 个 名 称 为 HtmlInputCheckBox. aspx 的 网 页 , 当 用 户 改变 复 
选 框 的 选中 状态 ,并 单 击 “ 确 定 ” 按 钮 时 , 就 会 触发 Ts E a 
OnServerChange 事件 ,进而 在 下 方 以 红色 字体 显示 相 s 


i 
i HimllzputCheckBox RH onSemverChange 事件 i 


关 信息 ,运行 界面 如 图 3-5 所 示 。 Ss 
(1) 各 控件 的 属性 和 事件 设置 见 表 3-2。 Hs 例 3-4 运行 界面 
表 3-2 例 3-4 控件 的 属性 和 事件 设置 

控件 类 型 ID 属性 和 事件 设置 

Value 一 "电影 " 
复 选 杠 ebherl OnServerChange= "Checkboxl ServerChange" 
提交 按钮 Submitl Value "f Ac" 
Span 控件 Spanl Style "Color; Red" 


(2) .cs 文件 的 代码 如 下 : 


protected void Checkboxl ServerChange (object sender, EventArgs e) 
{ 

Span1.EnableViewState= false; 

Span1.InnerText= "Html InputCheckBox 发 生 OnServerChange 事件 "; 
) 


7. Htmlinputimage 控件 

HtmlInputImage 控件 称 为 图 像 按 钮 ,对 应 的 HTML 标记 为 二 input type— "image", 

常用 属性 和 事件 如 下 : 

(1) Alt="…"”: 设置 图 像 的 替换 文字 ,替换 文字 只 有 在 无 法 读 取 图 像 或 图 像 尚未 下 载 
完成 时 才 会 显示 。 

(2) Src 二 "…" ; 设置 要 显示 的 图 像 文 件 的 路 径 。 

(3) OnServerClick— "PR" : 事件 参数 为 ImageClickEventArgs, 有 X、Y 两 个 属性 。 
(X,Y) 返 回 图 像 被 单 击 的 位 置 。 

[8503-5] 在 站 点 中 添加 一 个 名 称 为 HtmlInputImage. aspx 的 网 页 , 当 鼠 标 指 针 离 开 
HtmlInputImage 控件 时 显示 图 像 A, 将 鼠标 指针 移入 HtmlInputImage 控件 时 显示 图 像 B. 
当 单 击 图 像 的 某 个 位 置 时 ,将 会 在 图 像 下 方 显示 被 单 击 的 位 置 。 

(OD 用 户 界 面 的 HTML 代码 如 下 : 


< form id- "forml" runat="server"> 
«input type-" image" id-"I1" 
images/011.jpg'"src-". ./images/011.jpg" width- "83"height- "97"runat- "server" onserverclick 
-"showl"style- "width: l69px; height: 192px'» «br/» «br/» 


—"src- '../images/010. jpg ' "onmouseout- "src- '../ 


«span id-"spanl" runat- "server'"»« /span» 
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</fom> 
(2) .cs 文件 的 代码 如 下 : 


protected void show] (object sender, ImageClickEventArgs e) 
t 

spanl.InnerHtml=" 鼠 标 位置 为 : ("eX ", "e. Ye)"; 
) 


8. HtmllnputFile 控件 

HtmlInputFile 控件 的 常用 属性 如 下 : 

(D) Accept= "text/plain" : 设置 上 传 文件 的 类 型 。 

(2) Size=n; 设置 控件 的 宽度 ,单位 为 字符 。 

(3) PostedFile: 获取 上 传 的 文件 , 它 是 一 个 HttpPostedFile 对 象 ,包含 如 下 属性 与 
方法 。 

(D ContentLength: 获取 上 传 文件 的 大 小 。 

@ ContentType: 获取 上 传 文件 的 类 型 。 

@ FileName; 获取 文件 在 客户 端的 完整 路 径 。 

(D SaveAs(" 文 件 名 "): 将 上 传 的 文件 以 指定 文件 名 保存 在 服务 器 中 。 若 服务 器 已 存 
在 同名 的 文件 , 则 将 其 覆盖 。 

【 例 3-6】 在 站 点 中 添加 一 个 名 称 为 HtmlInputFile. aspx 的 网 页 , 当 用 户 选择 一 个 文 
件 并 单 击 “* 上 传 ”按钮 时 ,被 选择 的 文件 就 会 被 上 传 到 服务 器 中 ,并 在 该 页 上 显示 文件 名 、 内 
容 类 型 和 字 节 数 等 信息 。 

(OD 用 户 界面 的 HTML 代码 如 下 : 


< form id- "forml" runat="server" enctype= "multipart/form- data"> 
请 选择 上 传 的 文件 
«input runat="server" type- "file" id= "Fl"> 
«p» «input runat="server" type="submit" value-" [- f£ " id- "Bl" onserverclick-"bl click" 
></p> 
<div id= "wl" visible- "false" runat="server"> 
您 上 传 的 文件 名 为 :< span id="filename" runat- "server"/» «br» 
文件 类 型 为 :< span id- "filetype" runat- "server"/» «br» 
文件 长 度 为 :< span id- "filelength" runat- "server"/»*f t «br» 
上 传 到 :< span id- "Spanl" runat- "server"/» 
«/div» 

</fom> 


(2) .cs 文件 的 代码 如 下 : 


protected void bl click (object sender, EventArgs e) 
i 
wl.Visible-true; 
// 获 取 上 传 的 文件 名 
String fs=Path.GetFileName (Fl.PostedFile.FileName); 
filename.InnerHtml- fs; 
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filetype.InnerHtml-Fl.PostedFile.ContentType; 
filelength.InnerHtml- Fl.PostedFile.ContentLength.ToString|(); 
F1.PostedFile.SaveAs (Server .MapPath (". ./images/"+ fs)) ; 
Span1.InnerHtml- Server.MapPath (". . /images/"4 fs) ; 
" 
程序 说 明 : Path 是 一 个 类 名 ,位 于 命名 空间 System. IO 中 。Path. GetFileName XC 4# 
路 径 ) 用 于 获得 最 底层 的 文件 名 。 


9. HtmlTextArea 控件 

HtmlTextArea 控件 称 为 多 行文 本 框 , 对 应 的 HTML fiit Jy —textarea7 。 

常用 属性 与 事件 如 下 : 

(D Rows=n: 设置 多 行文 本 框 的 行 数 。 

(2) Cols=n: 设置 多 行文 本 框 的 列 数 。 

(3) Value=="…": 设置 多 行文 本 框 显 示 的 内 容 。 

(4) OnServerChange— " RUE": 当 服务 器 检查 到 多 行文 本 框 的 Value 值 作 了 改变 ， 
就 会 触发 该 事件 。 


10. HtmlSelect 控件 

HtmlSelect 控件 称 为 下 拉 框 ,对 应 的 HTML fiii Jg — select 。 

常用 属性 与 事件 如 下 : 

(1) DataSource— ArrayList 对 象 /String 数组 名 : 设置 要 绑 定 的 数据 源 。 

(2) Items: 选项 集合 ,用 来 存放 下 拉 框 的 全 部 选项 ,包括 如 下 属性 和 方法 。 

(D Items. Count 属性 : 返回 下 拉 框 包含 选项 的 个 数 。 

@ Items. Add( "选项 文本 ") : 向 下 拉 框 中 添加 选项 。 

© Items. ClearO : 清除 下 拉 框 的 全 部 选项 。 

@ Items. Remove( "选项 文本 ") : 清除 下 拉 框 的 指定 选项 。 

(3) Items[n]: 表示 n(n 宇 0) 号 选项 , 它 是 一 个 对 象 名 ,有 如 下 属性 。 

(D Items[n]. Selected— true/false: 设置 n 号 选项 是 否 被 选中 。 

@ Items[n]. Value: 返回 n 号 选项 的 值 。 

(4) SelectedIndex: 返回 所 选择 的 选项 的 下 标 。 

(5) Value: 返回 选中 项 目的 值 。 

(6) OnServerChange 二 "函数 名 ": 当 服 务 器 检查 到 下 拉 框 中 的 选取 项 发 生变 化 后 ,就 
会 触发 该 事件 。 

向 下 拉 框 中 添加 选项 有 以 下 3 种 方法 。 

d) f£ option 5j — /option- Z [8] BE E 16 Ji 

(2) 通过 DataSource 属性 动态 设置 选项 ,格式 如 下 : 


DataSource-ArrayList 对象/String 数 组 名 
(3) 通过 Items 属性 动态 设置 选项 ,格式 如 下 : 
Items Add ("选项 文本 ") 
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【 例 3-7】 在 站 点 中 添加 一 个 名 称 为 HtmlSelectl. aspx 的 网 页 ,为 下 拉 框 添加 white, 


lightgreen ,blue, black 选项 , 当 用 户 在 文本 框 中 p 
输入 一 种 颜色 并 单 击 “ 添 加 ”按钮 时 ,就 能 向 下 拉 | PES EU | 
框 中 追加 一 个 选项 ; 当 用 户 选择 下 拉 框 中 的 一 种 “| SEPE | ep RE : 
颜色 并 单 击 “ 确 定 ” 按 钮 时 ,就 能 改变 下 方 文字 的 ooo UIRA OO i 
颜色 ,设计 界面 如 图 3-6 所 示 。 mas 例 3.7 设 计 界 面 


(1) 各 控件 的 属性 设置 见 表 3-3。 
表 3-3 例 3-7 控件 的 属性 设置 


控件 类 型 ID 属性 设置 控件 类 型 ID 属性 设置 
文本 框 TI 普通 按钮 B2 Value "f Jin" 
下 拉 框 Di 普通 按钮 B1 Value 一 "确定 " 
Span 控件 spanl  |EnableViewState— "false" 


(2) .cs 文件 的 代码 如 下 : 


protected void b2 click(object sender, EventArgs e) 
{ 
D1.Items.Add(T1.Value); 


) 
protected void bl click(object sender, EventArgs e) 


{ 
Spanl.Style.Add("color", D1.Value); 
Spanl.InnerHtml- spanl.InnerHtml* Dl.Value; 


) 

[953-8] 在 站 点 中 添加 一 个 名 称 为 HtmlSelect2. aspx 的 网 页 ,在 加 载 页 面 之 后 ,下 拉 
框 中 才 会 显示 春 、 夏 、 秋 、 冬 4 个 选项 , 当 用 户 选 择 一 个 选项 并 单 击 “ 确 定 ” 按 钮 时 ,就 会 在 下 
方 标签 中 显示 相应 的 信息 ,设计 界面 如 图 3-7 所 示 。 


(1) 各 控件 的 属性 设置 见 表 3-4。 
表 3-4 例 3-8 控件 的 属性 设置 


控件 类 型 ID 属性 设置 
下 拉 框 Di 

提交 按钮 Bl Value 一 "确定 " 
Span 控件 spanl 


图 3-7 3-8 设计 界面 


(2) .cs 文件 的 代码 如 下 : 


protected void Page Load(object sender, EventArgs e) 

t 
ArrayList listl- new ArrayList(); // 定 义 一 个 数组 列表 对 象 
listl.Add(""); /为 各 选项 设置 文本 
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list1.Add(" 春 "); 
list1.AGd(" 夏 "); 
list1.AGd(" 秋 "); 
list1.AGd(" 冬 "); 
if(!Page.IsPostBack)Dl.DataSource-listl; 
D1.DataBind(); 
) 
protected void bl click(object sender, EventArgs e) 
i 
spanl.InnerHtml- "您 选择 的 是 : "« D1.Value* "X"; 
) 


11. HtmlTable 控件 

一 个 表格 (Table) 由 若干 表 行 (Row) 组 成 ,而 每 个 表 行 由 若干 单元 格 (Cell) 组 成 ,因此 
在 使 用 HtmlTable 控件 时 ,还 要 引入 HtmlTableRow 控件 和 HtmlTableCell 控件 。 

(D HtmlTableCell 控件 的 常用 属性 

(D c. InnerText= "…": 设置 单元 格 的 内 容 。 

Q) Align 二 "…" ; 设置 单元 格 内容 的 水 平 对 齐 方式 。 

@ ColSpan— "n" ; 设置 单元 格 占用 的 列 数 。 

(D RowSpan— "n" ; 设置 单元 格 占用 的 行 数 。 

@@VAlign 二 "…" ; 设置 单元 格 内 容 的 垂直 对 齐 方式 。 

© Width—"n" : 设置 单元 格 的 宽度 。 

(2) HtmlTableRow 控件 的 常用 属性 

(D Align="…": 设置 某 一 表 行 中 所 有 单元 格 内 容 的 水 平 对 齐 方式 。 

@ Cells. 单元 格 集合 ,用 于 存放 某 一 表 行 中 的 全 部 单元 格 ,包含 如 下 属性 和 方法 。 

* Cells. Count; 返回 表 行 所 含 单元 格 的 个 数 。 

* Cells. Add(HtmlTableCell fF) : 向 表 行 添加 单元 格 。 

@ Height="…": 设置 表 行 的 高 度 。 

(3) HtmlTable 控件 的 常用 属性 

(D Align="…": 设置 表格 在 网 页 中 的 对 齐 方式 。 

Q) Rows: 表 行 集合 ,用 于 存放 表格 的 全 部 表 行 ,包含 如 下 属性 和 方法 。 

* Rows. Count: 返回 表格 所 含 的 行 数 。 

* Rows. Add( HtmlTableRow 控件 ): 向 表格 中 添加 表 行 。 

@ Width—"--" ; 设置 表格 的 宽度 。 

在 C# 中 ,表格 第 一 行 的 序号 为 0, 第 一 个 单元 格 的 序号 为 0。 

【 例 3-9】 在 站 点 中 添加 一 个 名 称 为 HtmlTablel. aspx 的 网 页 ,第 一 次 加 载 页 面 时 , 仅 
显示 上 方 表格 。 当 用 户 从 下 拉 框 中 选择 一 个 行 数 和 一 个 列 数 ,并 单 击 “ 产 生 表格 ”按钮 时 , 才 
能 在 网 页 下 方 产生 一 个 动态 表格 。 运 行 界面 如 图 3-8 所 示 。 

(1) 设置 表格 行 数 的 下 拉 框 ID 名 为 D1 ,设置 表格 列 数 的 下 拉 框 ID 名 为 D2, 两 个 下 拉 
框 各 有 5 个 选项 。 下 方 表格 对 应 的 HTML 代码 如 下 : 


«table runat-"server" id-"tablel" width-"400" align-"center" border-"1" bordercolor- 
"plue"»« /table» 
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表格 列 数 ， | A 
(0,0) (0,1) (0,2) 
(1,0) (1,1) (1,2) 
(2,0) (Q.D (22) 


图 3-8 例 3-9 运行 界面 
(2) .cs 文件 的 代码 如 下 : 


protected void Page Load(object sender, EventArgs e) 
t 
if (Page.IsPostBack) 
t 
int numrows- int.Parse (D1.Value); 
int numcells- int.Parse (D2.Value); 
for (int i-0; i«numrows; i++) 
t 
HtmlTableRow r-new HtmlTableRow(); 
for (int j=0; j«numcells; j++) 
{ 
HtmlTableCell c=new HtmlTableCell (); 
c.InnerText="("+i+","+j+")"; 
r.Cells.Add(c); 
r.Cells[j].Align- "center"; 
) 
tablel.Rows.Add(r); 


) 


12. Htmllmage 控件 


HtmlImage 控件 称 为 图 像框 ,对 应 的 HTML fiie y <img> ,常用 属性 和 事件 如 下 : 
(D Alt="…”: 设 置 图 像 的 替换 文字 ,替换 文字 只 有 在 无 法 读 取 图 像 或 图 像 尚 未 下 载 


完成 时 才 会 显示 。 
(2) Sre- "--" ; 设置 要 显示 的 图 像 文 件 的 路 径 。 
(3) OnServerClick 二 "函数 名 " : 事件 参数 为 EventArgs。 


3.3 Web 控件 


5 HTML 控件 相 比 , Web 控件 提供 的 功能 更 加 强大 ,在 . NET 开发 中 ,建议 尽 可 能 使 
用 Web 控件 取代 HTML 控件 。Web 控件 位 于 System. Web. UI. WebControls 命名 空 


间 中 。 
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3.3.1 Web 控件 的 通用 属性 


Web 控件 共有 的 属性 如 下 : 

(1) AccessKey= "字符 ": AccessKey 只 能 接收 一 个 字符 ,例如 AccessKey=" S", 4H 
Pik Alt 十 S 组 合 键 时 ,表示 单 击 该 控件 。 

(2) Enabled=true/false; 决定 Web 控件 是 否 可 用 ,默认 为 true, 

(3) Text "^; 设置 Web 控件 的 值 。 


3.3.2 Label 控件 


Label 控件 称 为 标签 控件 ,只 能 用 来 显示 静态 文字 ,这 些 文字 用 做 指示 性 说 明 。 
Label 控件 的 声明 格式 如 下 : 


<asp:Label runat="server" id- "wl" Text="…"/> 


«Label runat="server" id-"wl"»-*:« /Label» 


3.3.3 TextBox 控件 


TextBox 控件 用 来 制作 文本 框 、 密 码 框 .多 行文 本 框 ,可 以 显示 文本 ,也 可 以 用 于 输入 文 
Æ. TextBox 控件 常用 的 属性 及 事件 如 下 : 

(D. Text="…": 设置 TextBox 控件 显示 的 内 容 。 

(2) Columns=n: 设置 TextBox 控件 的 宽度 ,单位 为 字符 数 。 

(3) MaxLength = n; 设置 最 多 可 以 输入 的 字符 数 ,只 有 将 TextMode 设置 为 
SingleLine 或 PassWord 时 ,该 属性 才 有 效 。 

(4) AutoPostBack- true/false; 当 TextBox 控件 的 Text 值 改变 时 ,决定 是 否 自 动 提 
交 , 默 认为 false。 

(5) TextMode— "*-"; 设置 TextBox 控件 的 类 型 。 在 默认 情况 下 ,TextMode 设置 为 
SingleLine, 创 建 只 包含 一 行 的 文本 框 ;设置 为 MultiLine 时 可 以 创建 包含 多 行 的 文本 框 ; 设 
置 为 PassWord 时 可 以 创建 单行 密码 框 ,用 户 输入 的 文字 显示 为 * 。 

(6) OnTextChanged 二 "函数 名 ": 当 服 务 器 检查 到 控件 的 Text 值 发 生变 化 后 ,就 会 触 
发 该 事件 。 

【 例 3-10】 使 用 TextBox 控件 处 理 OnTextChanged 事件 。 

(1) 在 站 点 中 添加 一 个 名 称 为 TextBox. aspx 的 网 页 。 

(2) 将 两 个 TextBox 控件 拖 到 该 页 面 上 ,在 “属性 ”窗口 中 设置 TextBoxl 控件 的 
AutoPostBack 属性 为 true. TextBox2 控件 的 ReadOnly 属性 为 true; 然后 双击 TextBoxl 
控件 ,在 事件 处 理 函 数 TextBoxl_TextChanged () 中 添加 如 下 代码 : 


TextBox2.Text- TextBoxl.Text; 


(3) 单 击 “运行 ?按钮 ,在 第 一 个 文本 框 中 输入 文字 并 转移 焦点 ,或 按 Enter 键 后 ， 
TextBox2 将 同步 显示 TextBoxl 中 的 内 容 , 显 示 结 果 如 图 3-9 所 示 。 
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图 3-9 TextBox 触发 OnTextChanged 事件 


3.3.4 Button 控件 


Button 控件 可 以 用 来 创建 提交 按钮 与 命令 按钮 ,在 服务 器 端 执行 后 都 会 转换 为 标记 
<input type— "submit" , 

命令 按钮 有 CommandName 与 CommandArgument 两 个 属性 ,提交 按钮 没有 。 

命令 按钮 的 单 击 事件 为 OnCommand. 事件 参数 为 CommandEventArgs. 有 
CommandName CommandArgument 两 个 属性 ;提交 按钮 的 单 击 事件 为 OnClick, 事 件 参数 
为 EventArgs。 

【 例 3-11】 在 站 点 中 添加 一 个 名 称 为 Button. aspx 的 网 页 ,初始 界面 如 图 3-10 所 示 ， 
当 单 击 First 按钮 时 ,会 在 Labell 标签 中 显示 命令 按钮 的 相关 信息 , 单 击 Second 按钮 时 ,会 
在 Label2 标签 中 显示 提交 按钮 的 相关 信息 。 

(1) 两 个 Button 控件 的 属性 及 事件 设置 见 表 3-5 。 


表 3-5 Button 控件 的 属性 及 事件 设置 


i i 

i Exi] i 控件 ID 属性 及 事件 设置 

Baa m 服务 器 控件 
! ! CommandArgument— "Web " CommandName— " x 
Do Exe) i 

pn— E uon Text— "First" OnCommand- "Buttonl Click" 
图 3-10 例 3-11 初 Button2 | OnClick— "Button2 Click" Text= "Second" 

始 界面 


(2) f£. cs 文件 中 添加 如 下 代码 : 


protected void Buttonl Click (object sender, CommandEventArgs e) 


Labell.Text- "你 单 击 的 是 : "+e.CommandName+ "- "+e.CommandArgument+ "命令 按钮 "; 


protected void Button2 Click(object sender, EventArgs e) 


Label2.Text=" 你 单 击 的 是 提交 按钮 "; 
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3.3.5 DropDownList 与 ListBox 控件 


DropDownList 控件 称 为 下 拉 框 ,用 户 每 次 只 能 选择 一 个 选项 ,有 默认 的 选项 。ListBox 
控件 称 为 列表 框 , 用 户 每 次 可 选择 一 个 或 多 个 选项 ,没有 默认 的 选项 。 


1. DropDownList 控件 

DropDownList 控件 的 常见 属性 及 事件 如 下 : 

(1) AutoPostBack— true/false; 当 控件 的 选项 改变 时 ,决定 是 否 自动 提交 ,默认 为 false。 

(2) SelectedIndex; 获取 选中 选项 的 下 标 。 

(3) SelectedValue: 获取 选中 选项 的 Value 值 。 

(4) SelectedItem: 获取 选中 的 选项 , 它 是 一 个 对 象 ,包含 Value 与 Text 属性 。 

(5) Items: 选项 集合 ,用 来 存放 控件 的 全 部 选项 。 

Items. Count 属性 : 返回 控件 包含 选项 的 个 数 。 

(6) Items[ n]: 表示 n(n 这 0) 号 选项 , 它 是 一 个 对 象 名 ,包含 如 下 属性 。 

(D Items[n]. Selected= true/false; 设置 n 号 选项 是 否 被 选中 。 

@ Items[n]. Value; 返回 n 号 选项 的 值 。 

(3) Items[n]. Text: 返回 n 号 选项 的 文本 。 

(7) OnSelectedIndexChanged — " PRU": 当 服务 器 检查 到 所 选择 的 选项 发 生变 化 后 ， 
就 会 触发 该 事件 。 

向 下 拉 框 中 添加 选项 有 3 种 方法 。 

(1) fi asp: ListItem2 5 — /asp: ListItem> Zz [] Bt TE 16 Ji 

(2) 通过 DataSource 属性 动态 设置 选项 ,格式 如 下 : 


DataSource- ArrayList 对 象 /String 数组 名 
(3) 通过 Items 属性 动态 设置 选项 ,格式 如 下 : 
Items Add ("选项 名 ") 


【 例 3-12】 在 站 点 中 添加 一 个 名 称 为 DropDownListl. aspx 的 网 页 ,初始 界面 如 图 3-11 
所 示 。DropDownList 控件 保存 了 “北京 “上 海 "“ 深 圳 ”“ 广 州 "“ 成 都 "“ 西 安 ”6 个 选项 。 
当 用 户 选择 一 个 选项 并 单 击 “ 确 定 ” 按 钮 时 ,就 会 在 标签 中 显示 “你 居住 的 城市 是 X X”。 

在 设计 视图 中 ,双击 “确定 ”按钮 ,在 事件 处 理 函 数 B1_Click () 中 添加 如 下 代码 : 


Message.Text=" 你 居住 的 城市 是 : "+ DropDownl .SelectedValue; 


I xa E 

BE | impe. Beeni 

| Eg ! i fasen] | 
图 3-11 bri 初始 界面 图 3-12 fA 3-13 初始 界面 


【 例 3-13】 在 站 点 中 添加 一 个 名 称 为 DropDownList2. aspx 的 网 页 ,初始 界面 如 图 3-12 
所 示 。 当 加 载 页 面 时 会 在 DropDownList 控件 中 显示 各 选项 ,当选 择 一 个 选项 时 ,会 在 标签 
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中 显示 该 选项 的 相应 信息 。 
CD 在 设计 视图 中 ,将 下 拉 框 movieTheater 的 AutoPostBack 属性 设置 为 true, 双 击 下 
拉 框 引出 事件 处 理 函 数 movieTheater_SelectedIndexChanged。 


(2) 在 . cs 文件 中 编写 代码 : 


protected void Page Load(object sender, EventArgs e) 
t 
if (!Page.IsPostBack) 
{ 
movieTheater.Items.Add ("国宾 戏院 "); 
movieTheater. Items .Add ("RÆ RBE") ; 
movieTheater.Items.Add ("H 3j 3R Dc ") ; 
movieTheater.Items.Add ("AE 4E 3 Dc ") ; 


) 
protected void movieTheater SelectedIndexChanged (object sender, EventArgs e) 


t 
Labell.Text- "你 选择 的 戏院 为 : "« movieTheater.SelectedItem.Value; 


) 


[95] 3-14] 在 站 点 中 添加 一 个 名 称 为 DropDownList3. aspx 的 网 页 ,初始 界面 如 图 3-13 
所 示 。 当 加 载 页 面 时 会 在 DropDownList 控件 中 显示 各 选项 , 当 
用 户 选择 一 个 选项 并 单 击 “ 确 定 ” 按 钮 时 ,会 在 标签 中 显示 相应 
的 信息 。 

CD 在 设计 视图 中 ,双击 “确定 ”按钮 Buttonl 引出 事件 处 理 
PR Buttonl_Click 。 

(2) 在 .cs 文件 中 编写 代码 : 


protected void Page Load(object sender, EventArgs e) 
{ 
String[]zy- ( "Ifi", "FÆ", "LA"; 
if(!IsPostBack) 
{ 
DropDownListl.DataSource- zy; 
DropDownListl.DataBind(); 


L 
图 3-13 例 3-14 初始 界面 


} 
protected void Buttonl Click(object sender, EventArgs e) 
{ 
Labell.Text- "你 选择 的 是 : "+ DropDownListl.SelectedValue; 


H 


2. ListBox 控件 
ListBox 控件 的 属性 及 事件 与 DropDownList 控件 大 致 相同 ,ListBox 控件 独 有 的 属性 
AT: 
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SelectionMode 二 "…": 设置 ListBox 控件 的 选择 模式 ,可 以 单 选 , 也 可 以 多 选 。 

【 例 3-15】 在 站 点 中 添加 一 个 名 称 为 ListBox. aspx 的 网 页 ,初始 界面 如 图 3-14 所 示 ， 
当 加 载 页 面 后 ,左边 的 ListBox 控件 会 显示 各 选项 。 当 用 户 单 击 之 之 按钮 时 ,会 将 左边 
ListBox 控件 的 全 部 选项 移动 到 右边 ; 当 用 户 选择 左边 ListBox 控件 的 一 个 或 多 个 选项 并 单 
击 之 按钮 时 ,会 将 选中 的 选项 移动 到 右边 。 志 二 到 按钮 是 将 选项 从 右 移动 到 左 , 其 他 功能 
与 之 .> 相同 。 


符 选 城市 壤 欢 的 城市 


四 四 PA 


3-4 例 3-15 初始 界面 


(1) 在 设计 视图 中 ,将 两 个 ListBox 控件 的 SelectionMode 属性 均 设 置 为 Multiple, 左 、 
HPA ListBox 控件 的 ID 名 分 别 为 ListBoxl、ListBox2, 并 双击 4 个 Button 控件 引出 事件 
处 理 函数 。 

(2) 在 .cs 文件 中 编写 代码 : 


protected void Page Load(object sender, EventArgs e) 
t 
string[] city- ( "北京 ", "上 海 ", "RÆ", "EK", "广州 ", "沈阳 ", WR", "成 都 ", "西安 ",，" 
Mk" y; 
if (!Page.IsPostBack) 
{ 
ListBoxl.DataSource- city; 
ListBoxl.DataBind(); 
) 
} 
protected void Buttonl Click (object sender, EventArgs e) 
{ 
// 全 部 添加 到 右边 
if (ListBoxl.Items.Count» 0) 
{ 
dnt i; 
for (i70; i«ListBoxl.Items.Count; i++) 
ListBox2.Items.Add (ListBoxl.Items[i].Text); 
ListBoxl.Items.Clear(); 
L 
H 
protected void Button4 Click(object sender, EventArgs e) 
t 
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// 全 部 添加 到 左边 
if (ListBox2.Items.Count» 0) 
{ 
inti; 
for (i-0; i«ListBox2.Items.Count; i++) 
ListBoxl.Items.Add (ListBox2.Items[i].Text); 
ListBox2.Items.Clear(); 


) 
protected void Button2 Click(object sender, EventArgs e) 
{ 
// 选 中 选项 到 右边 
int i; 
if (ListBoxl.SelectedIndex>- 1) 
{ 
for (i20; i«ListBoxl.Items.Count; i++) 
{ 
if (ListBoxl.Items[i].Selected) 
{ 
ListBox2.Items.Add(ListBoxl.Items[i].Text); 
ListBoxl.Items.Remove (ListBoxl.Items[i]); 


) 
protected void Button3 Click(object sender, EventArgs e) 
{// 选 中 选项 到 左边 
inti; 
if (ListBox2.SelectedIndex» - 1) 
t 
for (i20; i«ListBox2.Items.Count; i++) 
{ 
if (ListBox2.Items [i] .Selected) 
{ 
ListBoxl.Items.Add(ListBox2.Items[i].Text); 
ListBox2.Items.Remove (ListBox2.Items[i]); 


3.3.6 CheckBox 与 CheckBoxList 控件 


1. CheckBox 控件 
CheckBox 控件 称 为 复 选 框 ,常用 的 属性 及 事件 如 下 : 
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(D Text= "e": 设置 CheckBox 控件 的 文本 标签 。 

(2) TextAlign —"Right/ Left" ; 设置 文本 标签 与 CheckBox 控件 的 对 齐 方式 ,默认 为 Right。 

(3) Checked true/false; 设置 CheckBox 控件 的 选中 状态 。 

(4) AutoPostBack- true/false: 当 CheckBox 控件 的 Checked 值 改变 时 ,决定 是 否 自 
动 提交 ,默认 为 false。 

(5) OnCheckedChanged 二 "函数 名 "， 当 服务 器 检查 到 CheckBox 控件 的 Checked 值 发 
生变 化 后 ,就 会 触发 该 事件 。 

【 例 3-16】 在 站 点 中 添加 一 个 名 称 为 CheckBox. aspx 的 网 页 ,初始 界面 如 图 3-15 所 
示 , 当 用 户 在 “付款 地 址 "文本 框 中 输入 文字 并 选中 CheckBox 控件 时 ,“ 发 货 地 址 ”文本 框 中 
会 显示 同样 的 文字 。 
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(1) 各 控件 的 属性 及 事件 设置 见 表 3-6。 
表 3-6 例 3-16 控件 的 属性 及 事件 设置 


控件 类 型 ID 属性 及 事件 设置 
TextBox 控件 Sl Rows="6" TextMode= "MultiLine" 
TextBox 控件 S2 Rows="6" TextMode— "MultiLine" Enabled— "False" 
CheckBox 控件 C1 AutoPostBack- "True" OnCheckedChanged — "c1 click" 


(2) f£. cs 文件 中 编写 代码 : 


protected void cl click(object sender, EventArgs e) 
{ 

if (Cl.Checked) S2.Text=S1.Text; 

else S2.Text=""; 
) 


2. CheckBoxList 控件 

CheckBoxList 称 为 复 选 框 列 表 , 用 户 每 次 可 以 选择 多 个 选项 。 常 用 属性 及 事件 与 
ListBox 控件 基本 相同 ,这 里 不 再 袭 述 。 

【 例 3-17】 在 站 点 中 添加 一 个 名 称 为 | DERNE: RE 
CheckBoxList. aspx 的 网 页 ,初始 界面 如 图 3-16 (nsu DRR DARE 口 小 叮当 DERE 
所 示 , 当 用 户 选择 一 个 或 多 个 选项 时 ,都 会 立即 ipa 


在 标签 中 显示 选中 选项 的 文本 。 ”图 3.16 例 3.17 初 始 界面 s 


62 


ASP. NET 网 站 开发 案例 教程 


(1) 在 设计 视图 中 ,将 CheckBoxList 控件 的 AutoPostBack 属性 设置 为 True， 
RepeatDirection 属性 设置 为 Horizontal, 双击 CheckBoxList 控件 引出 事件 处 理 函数 Checkl_ 
SelectedIndexChanged。 

(2) f£. cs 文件 中 编写 代码 : 


protected void Checkl SelectedIndexChanged (object sender, EventArgs e) 
{ 

String s=" 您 选择 了 :<br>"; 

for (int i=0; i«Checkl.Items.Count; i++) 

t 

if (Checkl.Items[i].Selected) 
S-s*Checkl.Items[i].Value* "<br>"; 

) 

Labell.Text- s; 
) 


3.3.7 RadioButton 与 RadioButtonList 控件 


1. RadioButton 控件 

RadioButton 控件 称 为 单 选 按钮 ,常用 的 属性 及 事件 如 下 : 

(1) AutoPostBack= true/false: 当 单 选 按钮 的 Checked 值 改变 时 ,决定 是 否 自 动 提交 ， 
默认 为 false。 

(2) Checked= true/false; 设置 单 选 按钮 的 选中 状态 。 

(3) GroupName 王 "…": 设置 单 选 按 钮 所 属 的 组 名 。 

(4) OnCheckedChanged 二 "函数 名 ": 当 服务 器 检查 到 单 选 按钮 的 Checked 值 发 生变 
化 后 ,就 会 触发 该 事件 。 


2. RadioButtonList 控件 


RadioButtonList 控件 称 为 单 选 按钮 列表 ,用 户 每 次 只 能 选择 一 个 选项 ,常用 的 属性 及 
事件 与 DropDownList 控件 大 致 相同 。 


【 例 3-18】 在 站 点 中 添加 一 个 名 称 为 RadioButtonList. aspx 的 网 页 ,初始 界面 如 图 3-17 
所 示 , 当 用 户 选择 任 一 个 选项 并 单 击 “ 确 定 ” 按 钮 时 ,立即 在 标签 中 显示 选中 选项 的 文本 。 
EU EMEN | 
‘foss One Osme Onh ORÉ | 
| 加 | 


图 3-17 例 3-18 初始 界面 


d) 在 设计 视图 中 ,将 RadioButtonList 控件 的 RepeatDirection 属性 设置 为 
Horizontal, 双 击 Button 控件 引出 事件 处 理 函 数 Bl_Click。 
(2) E. cs 文件 中 编写 代码 : 


protected void Bl Click(object sender, EventArgs e) 
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if(Radiol.SelectedIndex»- 1) Message.Text- "您 选择 了 : "+Radiol.SelectedItem. Text; 


} 


3.3.8 Image 与 ImageButton 控件 


E] 


1. Image 12 


件 


Image 控件 称 为 图 像框 ,在 服务 器 端 执行 后 转换 为 HTML 标记 所 img 之 ,常用 属性 
WF: 
(D ImageUrl 王 "…": 设置 要 显示 的 图 像 文 件 的 路 径 。 

(2) AlternateText— — "="; 设置 图 像 的 替换 文本 ,替换 文本 只 有 在 无 法 读 取 图 像 或 
图 像 尚未 下 载 完成 时 才 会 显示 。 


无 标题 页 - Nicros 


文件 F) sip 查看 


性 及 


图 像 


于 返 


ImageButton 控件 的 ImageUrl 属性 值 。 
(2) 双击 ImageButton 控件 引出 事件 处 理 函 数 Bl1_ 
Click, 编 写 如 下 代码 : 


PES [93-19] 在 站 点 中 添加 一 个 名 称 为 Image. aspx 的 
o gaa” 局 | 网 页 ,要 求 在 Page Load 函数 中 将 Image 控件 的 图 片 源 设 
“| 置 为 Picture.jpg, 蔡 换文 本 设置 为 “灯塔 ”对 齐 方式 设置 
为 居中 对 齐 。 和 运行 界面 如 图 3-18 所 示 。 


2. ImageButton 控件 
ImageButton 控件 称 为 图 像 按 钮 ,在 服务 器 端 执行 后 
Hid HTML 标记 二 input type— "image", 


3-18 4| 3-19 运行 界面 ImageButton 控件 从 功能 上 看 和 Button 控件 一 样 ,但 


事件 如 下 : 


是 ImageButton 控件 是 用 图 像 作为 按钮 的 表面 。 常 用 属 


(D ImageUrl— "ee", 设置 要 显示 的 图 像 文 件 的 路 径 。 


(2) Alternat 


eText== "e"; 设置 图 像 的 替换 文本 ,替换 文本 只 有 在 无 法 读 取 图 像 或 


尚未 下 载 完 成 时 才 会 显示 。 
(3) OnClick— "PRI": 事件 参数 为 ImageClickEventArgs, 有 XX、Y 两 个 属性 。(X,Y) 用 
加 图 像 被 单 击 的 位 置 。 


[95/3-20] 应 用 ImageButton 控件 的 OnClick 事件 。 
d) 在 站 点 中 添加 一 个 名 称 为 InageButton. aspx 的 网 页 ,向 网 页 中 拖 入 一 个 ImageButton 
控件 和 一 个 Label 控件 。 在 “属性 ?窗口 中 设置 


protected void Bl Click (object sender, 
ImageClickEventArgs e) 


t 


Labell. text=" S HERUAR BOE ("+e.X+", "+e.Y+")"; 


} 


JEHAN - Kicrosoft In... [- |f) 
文件 中 dp FEV um " 


请 在 图 像 的 任意 位 置 上 单 击 。 


您 点 按 的 坐标 为 (108, 51) 


(3) 运行 程序 , 当 在 图 像 的 某 个 位 置 上 单 击 时 ,就 会 图 3-19 f 3-20 运行 界面 
在 图 像 下 方 显示 出 单 击 的 位 置 ,如 图 3-19 所 示 。 
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3.3.9 HyperLink 与 LinkButton 控件 


1. HyperLink 控件 
利用 HyperLink 控件 可 以 制作 文本 和 图 像 超 链接 ,功能 与 HTML 标记 所 a href = 


"…" 之 相似 。 
常用 属性 如 下 : 
(D) NavigateUrl 二 "…"; 设置 链接 到 的 网 页 文件 。 
(2) ImageUrl 二 "…"; 设置 超 链 接 的 图 像 。 
(3) Text="…": 设置 超 链接 的 文本 , 若 同时 设置 ImageUrl 与 Text 的 属性 值 , 则 以 


ImageUrl 为 准 ,Text 属性 值 变 成 图 片 的 蔡 代 文本 。 


2. LinkButton 控件 

LinkButton 控件 用 于 创建 超 链接 样式 的 按钮 。 该 控件 的 外 观 与 HyperLink 控件 的 相 
同 , 但 其 功能 与 Button 控件 的 一 样 。 

对 于 Web 访问 者 而 言 ,HyperLink .LinkButton 控件 是 一 样 的 ,但 它们 在 功能 方面 仍然 
有 较 大 的 差异 。 当 用 户 单 击 控件 时 , HyperLink 控件 会 立即 将 用 户 导 航 到 目标 URL, f 
不 会 被 回 送 到 服务 器 上 ;LinkButton 控件 则 首先 将 表单 发 回 到 服务 器 ,然后 将 用 户 导 航 到 
目标 URL。 如 果 在 “到 达 ” 目 标 URL 之 前 需要 进行 服务 器 端 处 理 , 则 使 用 LinkButton 控 
件 ; 如 果 无 须 进 行 服务 器 端 处 理 , 则 可 以 使 用 HyperLink 控件 。 


3.3.10 Panel 控件 


Panel 控件 是 一 个 可 以 放置 各 种 控件 的 容器 ,在 服务 器 端 执行 后 转换 为 HTML 标记 
«div ,利用 Panel 控件 ,可 以 对 网 页 中 的 相关 控件 进行 分 组 管理 并 进行 显示 或 隐藏 。 常 
用 属性 如 下 : 

(1) BackImageUrl — "URL"; 设置 面板 的 背景 图 片 。 

(2) Wrap true/false; 设置 面板 中 的 内 容 是 否 自动 换行 。 

【 例 3-21】 显示 或 隐藏 Panel 控件 示例 。 

(1) 在 站 点 中 添加 一 个 名 称 为 Panel. aspx 的 网 页 ,向 网 页 中 
拖 入 一 个 Panel 控件 和 一 个 Button 控件 ,向 Panel 控件 中 输入 文 
本 ,初始 界面 如 图 3-20 所 示 。 i 

(2) 双击 Button 控件 引出 事件 处 理 函数 Buttonl_Click, 编 [ER | 


[P| 
写 如 下 代码 : 3-20 f 3-21 初始 界面 
if (myPanel.Visible--true) 
{ 
myPanel.Visible- false; 
Buttonl.Text- "显示 面板 "; 


else 


myPanel.Visible-true; 
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Buttonl.Text- "隐藏 面板 "7 
) 


(3) 运行 程序 ,实现 Panel 控件 的 显示 和 隐藏 。 
3.3.11 Table 控件 


Table 控件 用 来 制作 表格 , 它 可 以 使 数据 的 输出 更 加 整齐 .美观 。Table 控件 和 
TableRow TableCell 控件 是 密 不 可 分 的 。 

Table 控件 用 来 声明 表格 ,而 TableRow 和 TableCell 控件 分 别 用 来 声明 表格 的 行 与 单 
元 格 。 它 们 的 关系 可 以 理解 为 : 一 个 Table 控件 包含 一 个 或 多 个 TableRow 控件 ;一 个 
TableRow 控件 包含 一 个 或 多 个 TableCell 控件 。 

Table 控件 的 声明 格式 如 下 : 


«asp:Table 
ID= "对 象 名 称 " 
Runat- "server" 
BackImageUrl- "背景 图 片 所 在 位 置 " 
CellSpacing- "单元 格 之 间 的 间距 " 
CellPadding- "单元 格 中 文字 和 单元 格 内 部 边界 之 间 的 距离 " 
HorizontalAlign- "整个 表格 水 平 对 齐 方式 " 


«asp:TableRow» 
«asp:TableCell/» 
< /asp:TableRow» 
< /asp:Table» 


注意 : 

(D) Table 控件 可 设置 表格 的 边框 、 对 齐 方式 、 网 格 线 ,常用 属性 : BorderWidth、 
HorizontalAlign,GridLines, 

(2) TableRow 控件 可 设置 单元 格 的 对 齐 方式 、 行 高 ,常用 属性 : HorizontalAlign, 
Height。 

(3) TableCell 控件 可 设置 单元 格 的 对 齐 方式 、 列 宽 、 单 元 格 合并 ,只 需 设置 第 1 行 单 元 
格 的 列 宽 即 可 ,常用 属性 ; HorizontalAlign、Width、RowSpan、ColumnSpan。 

下 面 介绍 利用 Table 控件 制作 如 表 3-7 所 示 的 表格 的 步骤 。 


表 3-7 表格 


学 号 姓 名 性 别 
语文 数学 


CD 将 页 面 切 换 到 “设计 ”视图 ,从 工具 箱 中 拖 动 一 个 Table 控件 到 页 面 上 。 
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(2) 在 “属性 ”窗口 中 将 Table 控件 的 Border Width 设置 为 1, HorizontalAlign 属性 设 
置 为 Center,GridLines 属性 设置 为 Both。 

(3) 设置 Table 控件 的 Rows 属性 , 单 击 Collection 右边 的 … 按 钮 ,打开 “TableRow 集 
合 编辑 器 ?对 话 框 ,如 图 3-21 所 示 。 


TableRow 集合 编辑 器 


RR: 
o 
1|Teblehor 


到 Taleao 
引 Trablegov 
E| TableRor 


EnsbleThening True 

EnableVierStat True 

SkixID 

ToolTip | 

Visible True 4 

日 杂项 | 

qn | 
vi 


(Collection) 


3-21 "TableRow 集合 编辑 器 ”对 话 框 


(4) 单 击 “ 添 加 ”按钮 5 次, 在“ 成员” 列表 框 中 出 现 Table 的 5 个 TableRow 控件 。 

(5) 在 左边 的 “成 员 ? 列 表 框 中 依次 选择 每 个 TableRow 控件 ,将 每 个 TableRow 控件 的 
Height 属性 设置 为 20px, HorizontalAlign 属性 设置 为 Center, 即 设置 了 行 高 .单元 格 的 对 
齐 方式 。 

(6) 在 “成 员 ” 列 表 框 中 选择 0 号 TableRow 控件 ,然后 在 右边 选择 该 控件 的 Cells 属 
性 , 单 击 Collection 右边 的 … 按 钮 ,打开 “TableCell 集合 编辑 器 "对话 框 ,如 图 3-22 所 示 。 

(7) 单 击 “ 添 加 ”按钮 5 次, 在“ 成员” 列表 框 中 出 现 5 个 TableCell 控件 。 同 理 , 为 1 一 
4 号 TableRow 控件 各 设置 5 个 TableCell 控件 ,设置 完成 后 , 单 击 两 次 “确定 ”按钮 ,返回 网 
页 页 面 ,结果 如 图 3-23 所 示 。 

TableCell 集合 编辑 器 
ER 


1|TableCell 
到 Tablecell Associatedead 
F| TableCel1 TabIndex 

4| TableCel1 


BackColor 
BorderColor 


BorderStyle 
Borderfidth 


EIEEE 


3-22 “TableCell 集合 编辑 器 ”对 话 框 3-23 Table 控件 


(8) f£ 0 号 TableRow 控件 的 “TableCell 集合 编辑 器 ?对 话 框 中 ,将 0 一 2 号 TableCell 
控件 的 Width 属性 设置 为 100px, RowSpan 属性 设置 为 2; 将 3 号 TableCell 控件 的 
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| 


ColumnSpan 属性 设置 为 2, Width 属性 设置 为 200px; 将 4 号 TableCell 控件 移 除 。 
(9) 在 1 号 TableRow 控件 的 “TableCell 集合 编辑 器 ”对 话 框 中 ,将 0~2 号 TableCell 
控件 移 除 ,返回 网 页 页 面 ,结果 如 图 3-24 所 示 。 


HW 
Lg Lg gue 
HH HH 
sum eum ceu GE GE 
aem HE HE Gd Lord 
Lg Lg gu Ld Lcd 
图 3-24 表格 雏形 


(10) 设置 各 个 TableCell 控件 的 Text 属性 值 。 
完成 以 上 步骤 后 ,切换 到 * 源 ”视图 ,可 以 看 到 自动 生成 的 代码 : 


< asp: Table ID="Tablel" runat-" server" BorderWidth-" 1px" HorizontalAlign =" Center" 
GridLines- "Both"» 

«asp: TableRow runat="server" Height- "20px" HorizontalAlign- "Center"» 
«asp:TableCell runat="server" RowSpan- "2" Width "100px"> 学 号 </asp:TableCell> 
<asp:TableCell runat="server" RowSpan- "2" Width="100px"> 姓 名 < /asp:TableCell» 
<asp:TableCell runat="server" RowSpan- "2" Width- "100px"'» f/E 9l] « /asp:TableCell» 
«asp:TableCell runat="server" ColumnSpan- "2" Width- "200px"> 成 绩 < /asp: 
TableCell» 

« /asp:TableRow» 

«asp: TableRow runat="server" Height- "20px" HorizontalAlign- "Center"» 

« asp:TableCell runat="server"> iB X< /asp:TableCell» 
«asp:TableCell runat="server">} < /asp:TableCell» 

< /asp:TableRow» 

«asp: TableRow runat="server" Height- "20px" HorizontalAlign- "Center"» 
«asp:TableCell runat="server"> &nbsp;« /asp:TableCell» 

«asp:TableCell runat="server"> &nbsp;« /asp:TableCell» 
«asp:TableCell runat="server"> &nbsp;« /asp:TableCell» 
«asp:TableCell runat- "server"» &nbsp;« /asp:TableCell» 
«asp:TableCell runat="server"> &nbsp;« /asp:TableCell» 

« /asp:TableRow» 

«asp:TableRow runat- "server" Width- "200px" Height- "20px" HorizontalAlign- "Center"> 
«asp:TableCell runat- "server"» &nbsp;« /asp:TableCell» 

«asp:TableCell runat="server"> &nbsp;« /asp:TableCell» 
«asp:TableCell runat="server"> &nbsp;« /asp:TableCell» 
«asp:TableCell runat="server"> &nbsp;« /asp:TableCell» 
«asp:TableCell runat="server"> &nbsp;« /asp:TableCell» 

< /asp:TableRow» 

«asp:TableRow runat="server" Height- "20px" HorizontalAlign- "Center" 
«asp:TableCell runat="server"> &nbsp;« /asp:TableCell» 

«asp:TableCell runat="server"> &nbsp;« /asp:TableCell» 
«asp:TableCell runat="server"> &nbsp;« /asp:TableCell» 
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«asp:TableCell runat="server"> gnbsp;< /asp:TableCell» 
«asp:TableCell runat="server"> &nbsp;« /asp:TableCell» 
< /asp:TableRow» 
« /asp:Table» 


[9513-22] 在 站 点 中 添加 一 个 名 称 为 Tablel. aspx 的 网 页 , 当 用 户 从 下 拉 框 中 选择 一 


个 行 数 和 一 个 列 数 ,并 单 击 “ 产 生 表格 ”按钮 时 ,就 能 产生 一 个 动态 表格 ,运行 界面 如 图 3-25 
所 示 。 


J 无 标题 页 - Nicrosoft Internet Explorer 
XH) SED SEV KEW IAV 帮助 
地 址 四 ) [Æ http://1ocalhost:1043/chap03/web/Tablel. aspx 


tk. bzs LECE) 


第 0 行 第 0 列 | 第 0 行 第 1 列 | 第 0 行 第 2 列 | 第 0 行 第 3 列 
第 1 行 第 0 列 | 第 1 行 第 1 列 | 第 1 行 第 2 列 | 第 1 行 第 3 列 


| 第 2 行 第 0 列 | 第 2 行 第 1 列 | 第 2 行 第 2 列 | 第 2 行 第 3 列 


3-25 f 3-22 运行 界面 


(1) 在 “设计 ”视图 中 ,将 Table 控件 的 CellPadding 属性 设置 为 4,CellSpacing 属性 设 
置 为 1 ,BorderWidth 属性 设置 为 1 ,Gridlines 属性 设置 为 Both。 
(2) 在 “设计 ”视图 中 ,双击 “产生 表格 ”按钮 ,引出 事件 处 理 函数 ,编写 如 下 代码 : 


int m= int.Parse (rowNumber.SelectedValue); 
int n= int.Parse (cellNumber.SelectedValue); 
for (int i=0; i«m; i++) 
{ 
TableRow r- new TableRow(); 
for (int j=0; j«n; j++) 
{ 
TableCell c-new TableCell(); 
c.Text- "B "eie" fj 5B ne je" Jl; 
r.Cells.Add(c); 
} 
myTable .Rows.Add (r) ; 


3.3.12 Calendar 控件 

Calendar 控件 用 于 在 Web 页 中 显示 一 个 日 历 ,用 户 可 以 选择 日 期 ,可 以 在 上 、 下 月 之 间 
移动 。 

Calendar 控件 由 9 个 部 件 组 成 ,不 同 组 成 部 件 采 用 不 同 的 样式 , 见 表 3-8。 

Calendar 控件 的 主要 属性 和 事件 : 

(1) NextPrevFormat: 设置 前 往 上 个 月 或 下 个 月 的 超 文 本 显示 方式 (默认 为 Custom 
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Text), 
当 NextPrevFormat — "Custom Text" 时 ,才能 设置 如 下 两 个 属性 值 : NextMonthText. 
BRUH; PrevMonthText SA Jy 
X 38 Calendar 控件 的 组 成 部 件 
组 成 部 件 采用 样式 组 成 部 件 采用 样式 

标题 栏 标题 样式 (TitleStyle) 今天 日 期 今天 日 期 样式 (Today DayStyle) 

标题 栏 导航 | 下 一 个 “前 一 个 ”样式 (NextPrevStyle) | 周末 日 期 ”| 周末 日 期 样式 (WeekendDayStyle) 
其 他 月 日 期 样式 (OtherMonth- 
DayStyle) 
选择 器 选择 器 样式 (SelectorStyle) 选取 日 期 SelectedDayStyle 
本 月 日 期 日 期 样式 (DayStyle) 


星期 区 段 日 期 标题 样式 (DayHeaderStyle) 其 他 月 日 期 


(2) SelectionMode; 设置 日 期 的 选择 模式 ,默认 为 Day。 

当 SelectionMode— "DayWeek/Day WeekMonth" Ilf ,才能 显示 选择 器 。 

当 SelectionMode 二 "DayWeek" 时 ,才能 设置 SelectWeekText 的 属性 值 。 

当 SelectionMode 二 "DayWeekMonth" 时 ,才能 设置 Select Week Text, SelectMonthText 
的 属性 值 。 

(3) OnselectionChanged 二 "函数 名 ": 当 用 户 选 择 某 天 、 某 周 或 某 月 时 就 会 自动 提交 ， 
并 触发 该 事件 。 

[813-23] 在 站 点 中 添加 一 个 名 称 为 Calendarl. aspx 的 网 页 ,向 网 页 中 拖 入 一 个 
Calendar 控件 和 一 个 Label 控件 ,并 对 Calendar 控件 进行 属性 设置 , 当 用 户 选 择 一 个 日 期 
时 ,Label 控件 会 显示 选择 的 日 期 ,执行 结果 如 图 3-26 所 示 。 


J EHM - Kicrosoft Internet Explerer ”全 | 器 | 区 | 
i Xt) SEO SEV KEW IAW 帮助 0 [] 
;地址 加 E] http://localhost: 1043/chspO3/web/Celendari [| EJ 和 到 


l 
| 


20 


EEEEEEE 


sa Je 
B BIS ne i 


3-26 Calendar 控件 的 应 用 


(OD 用 户 界 面 的 HTML 代码 : 


< form id- "forml" runat="server"> 


«Asp:Calendar runat="server" 
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id-"Calendarl" 

BorderColor- "Black" 
NextPrevFormat- "CustomText" 
PrevMonthText= "上 月 " 
NextMonthText= "下 月 " 


SelectionMode- "DayWeekMonth" 
SelectMonthText- " 整 月 " 
SelectWeekText= " 整 周 " 
OnSelectionChanged- "DayChange" Cel1Spacing= "1"» 
« TodayDayStyle BackColor- "OrangeRed"/» 
«SelectorStyle BackColor- "PaleTurquoise"/» 
«NextPrevStyle ForeColor- "Blue"/» 
< DayReaderStyle Font- Bold- "True" BackColor- "4 FFEEDD"/» 
«SelectedDayStyle ForeColor- "White" BackColor- "4 666666"/» 
«TitleStyle ForeColor- "Brown" BackColor- "# CCCCCC"/» 
«WeekendDayStyle BackColor- "4 FFFFCC"/» 
«OtherMonthDayStyle ForeColor- "LightGray"/» 
< /asp:Calendar» 
€br» «asp:Label runat="server" id- "Message" /» 
«/fomo 


(2) f£. cs 文件 中 编写 代码 : 


protected void DayChange (object sender, EventArgs e) 
{ 
Message.Text= "你 选择 的 日 期 是 : "+ Calendar1.SelectedDate.ToShortDateString () ; 


3.3.13 AdRotator 控件 


AdRotator 控件 是 ASP. NET 新 增 的 一 个 控件 。 当 访问 网 站 时 ,经 常会 看 到 网 页 上 各 
种 各 样 的 网 络 广告 。AdRotator 控件 就 是 ASP. NET 提供 的 一 种 广告 控件 , 它 用 来 呈现 一 
些 广告 图 像 , 单 击 这 些 图 像 将 会 定位 到 一 个 新 的 Web 位 置 。 它 的 作用 是 可 以 使 多 个 广告 交 
蔡 出 现 ,并 允许 某 些 广告 优先 于 其 他 广告 。 

在 使 用 AdRotator 控件 之 前 ,必须 定义 一 个 XML 格式 的 广告 文件 。 一 个 广告 文件 由 
志 Advertisements 二 开头 ,以 二 /Advertisements 过 结束, 中间 包含 若干 广告 ,每 个 广告 以 
到 Ad> 开 头 ,以 <</Ad>> 结 束 。 具 体格 式 如 下 : 


<?xml version-"1.0" encoding- "gb2312"?» 
«Advertisements» 
«Ad» 
<ImageUrl> 广 告 图 片 的 URL« /ImageUr1» 
<NavigateUr1> 单 击 广告 时 ,将 链接 到 哪个 网 址 < /NavigateUrl» 
<Alternatetext> 用 来 替代 的 文本 < /Alternatetext> 
<Keyword> 关 键 字 < /Keyword> 
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<Impressions> 广 告 出 现 频率 的 权重 值 < /Impressions» 
« /Ad» 
< /Advertisements» 


例如 ,在 站 点 中 编写 一 个 广告 文件 ADFile. xml, 代 码 如 下 : 


«?xml version-"1.0" encoding- "gb2312" ?> 
€ Advertisements» 
«Ad» 
< ImageUr1» . ./images/bookl . jpg« /ImageUrl» 
«NavigateUrl»bookl.htm« /NavigateUrl» 
«AlternateText» Visual Basic.NET fi J it iT « /A1ternateText» 
«Keyword» Visual Basic.NET T. « /Keyword» 
«Impressions» 20< /Impressions» 
« /Ad» 
«Ad» 
< ImageUrl» . ./images/book2. jpg« /ImageUrl» 
«NavigateUrl» book2.htm« /NavigateUrl» 
«AlternateText» Visual C£ .NET 程 序 设计 < /ALternateText» 
«Keyword» C£ .NET 工具 书 < /Keyword> 
< Impressions> 80< /Impressions> 
« /Ad» 
< /Advertisements» 


AdRotator 控件 的 语法 格式 如 下 : 


«asp: AdRotator 

idemen 

runat- "server" 

AdertismentFile- "广告 文件 的 路 径 " 
KeyWordFiter- "广告 的 关键 字 " 
Target= "新 页 面 打开 方式 " 
OnAdCreated- "事件 处 理 函 数 "/> 


OnAdCreated — "事件 处 理 函 数 ": 当 AdRotator 控件 被 创建 以 后 ,就 自动 触发 该 事件 ， 


并 将 某 个 广告 的 所 有 元 素 传递 给 事件 参数 AdCreatedEventArgs, 它 包含 AlternateText、 
ImageUrl, NavigateUrl 共 3 个 属性 。 


【 例 3-24】 利用 AdRotator 控件 显示 ADFile. xml 中 的 广告 。 
d) 在 站 点 中 添加 一 个 名 称 为 AdRotator. aspx 的 网 页 ,在 页 面 中 放置 一 个 AdRotator 


控件 和 一 个 Label 控件 。 


(2) 在 “设计 ”视图 中 将 AdRotator 控件 的 AdvertisementFile 属性 设置 为 ADFile. 


xml,BorderWidth 属性 设置 为 1。 


(3) 双击 AdRotator 控件 引出 事件 处 理 函 数 myAd_AdCreated, 在 该 函数 中 添加 如 下 


String ADInfo; 
ADInfo- E: 换文 本 : "+e.AlternateText; 
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ADInfo=ADInfo+ "<br> 图 片 源 地 址 : "+e.ImageUrl; 
ADInfo=ADInfo+ "<br> 链 接地 址 : "+e.NavigateUrl; 
ShowADInfo.Text- ADInfo; 


(4) 单 击 “ 运 行 ”按钮 ,将 在 浏览 器 中 随机 显示 广告 条 , 单 击 刷新 ,将 显示 不 同 的 图 片 , 运 
行 结果 如 图 3-27 所 示 。 
EE 


i xh SEO SEV KEW IAV 帮助 中 
地 址 加) dB] http://localhost: 4614/chap03/web/AdRotator. as 


替换 文本 ，Visual C#NET 程 序 设计 
源 地 址 ，. /imagesibook2 jpg 
链接 地 址 ，book2 htm 


3-27 AdRotator 控件 的 应 用 


3.4 验证 控件 


ASP. NET 功能 强大 的 一 种 体现 就 是 具有 丰富 的 Web 控件 ,本 节 将 介绍 验证 控件 和 各 
种 Web 数据 验证 方式 ,设计 成 了 通用 的 ASP. NET 控件 形式 。 验 证 控件 位 于 System. 
Web. UI. WebControls 命名 空间 中 。 


3.4.1 验证 控件 概述 


验证 控件 ,顾名思义 就 是 校 验 用 户 输入 数据 正确 性 的 控件 。 例 如 ,用 户 在 文本 框 中 输入 
数据 后 , 便 显 示 一 条 提示 信息 ,表明 校 验 的 数据 是 否 合法 。 验 证 的 过 程 可 以 在 服务 器 端 执 
行 ,也 可 以 在 客户 端 执行 。 在 客户 端 运行 的 校 验 代码 是 在 数据 被 提交 之 前 执行 的 ,因此 可 以 
提高 程序 的 性 能 。 

验证 控件 不 能 单独 使 用 ,必须 与 HTML 控件 或 Web 控件 集成 使 用 。 因 为 验证 控件 是 
用 来 验证 用 户 是 否 向 HTML 控件 (或 Web 控件 ) 中 输入 数据 ,输入 数据 的 格式 、 类 型 范围 
是 否 符合 要 求 的 。 

验证 控件 的 通用 属性 如 下 : 

(1) ControlToValidate: 设置 要 验证 的 控件 的 ID。 

(2) Display: 设置 错误 信息 的 显示 方式 ,默认 为 Static。 

None 表示 不 显示 错误 信息 ;Static 表示 无 论 是 否 发 生 错误 ,错误 信息 均 占 用 页 面 的 空 
间 ;Dynamic 表示 当 发 生 错误 时 ,错误 信息 才 占 用 页 面 的 空间 。 

(3) ErrorMessage: 设置 验证 失败 时 所 要 显示 的 错误 信息 ,错误 信息 同时 会 在 
ValidationSummary 控件 上 显示 出 来 。 若 与 Text 同时 存在 , 则 以 Text 为 准 。 

(4) Text: 设置 验证 失败 时 所 要 显示 的 错误 信息 , 但 错误 信息 不 会 在 
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ValidationSummary 控件 中 显示 出 来 。 
(5) IsValid: 判断 验证 控件 是 否 验证 成 功 ,该 属性 为 Page 对 象 和 验证 控件 专用 。 


3.4.2 验证 控件 的 类 型 

ASP. NET 一 共 包含 了 6 个 用 于 验证 的 服务 器 控件 ,每 个 控件 执行 特定 类 型 的 验证 , 且 
当 验 证 失败 时 显示 自 定义 消息 ,下 面 介绍 这 6 个 验证 控件 。 

1. RequiredFieldValidator 控件 


RequiredFieldValidator 控件 称 为 必需 字段 验证 ,用 来 判断 用 户 是 否 输入 数据 。 
RequiredFieldValidator 控件 的 声明 格式 如 下 : 


<asp:RequiredFieldValidator 
TO We 
runat= "server" 
ControlToValidate- "被 验证 控件 的 rp" 
ErrorMessage= "验证 失败 时 显示 的 错误 信息 " 
InitialValue=" 初 始 值 "/> 


iE. 

(1) 车 被 验证 的 控件 的 Value( 或 TexO fi 55 Initial Value 值 相等 , 则 必须 验证 控件 认为 
未 输入 数据 。 

(2) 若 用 户 没有 输入 数据 ,只 会 调用 RequiredFieldValidator 的 验证 规则 ,不 会 调用 其 
他 验证 控件 的 验证 规则 。 

[813-25] RequiredFieldValidator 控件 的 应 用 ,设计 界面 如 图 3-28 所 示 。 
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3-28 RequiredFieldValidator 控件 的 应 用 


(1) 在 站 点 中 添加 一 个 名 称 为 RequiredFieldValidator. aspx 的 网 页 。 
(2) 向 网 页 中 添加 一 些 控件 ,并 设置 属性 , 见 表 3-9. 


表 3-9 例 3-25 控件 的 属性 设置 


控件 类 型 ID 属性 设置 
TextBox Name Text= "请 输入 姓名 " 
RequiredFieldValidator R1 SeT HER py ia A 
TextBox SID 
RequiredFieldValidator R2 ControlToValidate= "SID" InitialValue= "" 


ErrorMessage 一 "您 忘 了 填写 身份 证 号 码 " 


Button Bl Text 二 "确定 ” 
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(3) 在 .cs 文件 中 编写 代码 : 


protected void Page Load(object sender, EventArgs e) 
t 

if (Page.IsPostBack) Response.Write ("Ok"); 
) 


2. RangeValidator 控件 
RangeValidator 控件 称 为 范围 验证 ,用 来 判断 用 户 输入 的 数据 是 否 介 于 某 个 范围 之 内 。 
RangeValidator 控件 的 声明 格式 如 下 : 


«asp:RangeValidator 
ID" 
runat- "server" 
ControlToValidate- "被 验证 控件 的 rp" 
MaximunValue- "最 大 值 " 
MinimunValue- "最 小 值 " 
Type- "数据 类 型 " 
ErrorMessage= "验证 失败 时 显示 的 错误 信息 "/> 


【 例 3-26] RangeValidator 控件 的 应 用 ,设计 界面 如 图 3-29 所 示 。 
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图 3-29 RangeValidator 控件 的 应 用 


d) 在 站 点 中 添加 一 个 名 称 为 RangeValidator. aspx 的 网 页 。 
(2) 向 网 页 中 添加 一 些 控件 ,并 设置 属性 , 见 表 3-10, 


X310 91326 控件 的 属性 设置 


控件 类 型 ID 属 性 B oW 

TextBox Score 

RequiredFieldValidator R2 Parisi dE dd ErrorMessage = " if ff A — 
个 分 数 " isplay— "Dynamic 
ControlToValidate= "Score" Type- "Integer" 

RangeValidator R1 MaximumValue="100" MinimumValue= "0" 
ErrorMessage= "成 绩 必 须 介 于 0 一 100 分 之 间 " 

Button B1 Text 一 "确定 " 


G) 在 .cs 文件 中 编写 代码 ; 


protected void Page Load(object sender, EventArgs e) 
t 
if(Page.IsPostBack) Response.Write ("Ok"); 


3. CompareValidator 控件 
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CompareValidator 控件 称 为 比较 验证 ,用 于 将 用 户 输入 的 数据 与 指定 的 数据 进行 比 


较 , 比 较 的 数据 可 以 是 常量 、 另 一 个 控件 的 值 。 
CompareValidator 控件 的 声明 格式 如 下 : 


<asp:CompareValidator 
IDE "en 


Runat= "Server" 


ControlToValidate- "被 验证 控件 的 rp" 


ControlToCompare- "比较 的 控件 " 
ValueTocompare= "比较 的 常量 " 
Type- "数据 类 型 " 

Operator- "比较 操作 " 


ErrorMessage= "验证 失败 时 显示 的 错误 信息 "/> 


其 中 , Operator 属性 指定 了 进行 比较 的 类 型 ,如 大 于 ,等 于 。 若 Operator 属性 取 
DataTypeCheck, 则 ControlToCompare 和 ValueToCompare 属性 将 被 忽略 。 
【 例 3-27] CompareValidator 控件 的 应 用 ,设计 界面 如 图 3-30 所 示 。 


图 3-30 CompareValidator 控件 的 应 用 


CD 在 站 点 中 添加 一 个 名 称 为 CompareValidator. aspx 的 网 页 。 


(2) 向 网 页 中 添加 一 些 控件 ,并 设置 属性 , 见 表 3-11. 
表 3-11 例 3-27 控件 的 属性 设置 
控件 类 型 ID 属性 设置 
ControlToValidate 一 "TextBox2” 
c Valid Co Validatorl ControlToCompare— "TextBox1" 
RE es RE Type="Double" Operator="LessThanEqual" 
ErrorMessage 一 "最 小 值 不 能 大 于 最 大 值 !" 
Button Buttonl Text 二 "确定 " 


(3) 在 .cs 文件 中 编写 代码 : 


protected void Page Load(object sender, EventArgs e) 


i 


if (Page.IsPostBack) Response.Write ("Ok"); 


) 


4. RegularExpressionValidator 控件 


RegularExpressionValidator 控件 称 为 正则 表达 式 验证 ,用 来 验证 用 户 输 入 的 数据 是 否 
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符合 指定 的 格式 。 
RegularExpressionValidator 控件 的 声明 格式 如 下 : 


«asp:RegularExpressionValidator 
Ipe "en 
runat="server" 
ControlToValidate= "被 验证 控件 的 ID" 
ValidationExpression- "验证 表达 式 " 
ErrorMessage= "验证 失败 时 显示 的 错误 信息 "/> 


[53-28] RegularExpressionValidator 控件 的 应 用 ,设计 界面 如 图 3-31 所 示 。 


3-31 RegularExpressionValidator 控件 的 应 用 


CD 在 站 点 中 添加 一 个 名 称 为 RegularExpressionValidator. aspx 的 网 页 。 
(2) 向 网 页 中 添加 一 些 控件 ,并 设置 属性 , 见 表 3-12. 
X31 91328 控件 的 属性 设置 


控件 类 型 ID 属性 设置 
. ControlToValidate— "Tel" Display "Dynamic" 
R Field Valid; R1 
Se E HO ErrorMessage 一 "请 输入 邮政 编码 ” 
ControlToValidate— "Tel" ValidationExpression— "Ad(6) " 
RegularExpressionValidator R2 ErrorMessage 一 "邮政 编码 格式 错误 " 
Button Bl Text 二 "确定 " 


对 于 身份 证 号 、 邮 政 编码 、 电 子 邮 件 地 址 及 电话 号 码 等 常用 字符 序列 ,可 以 利用 正则 表 
达 式 编辑 器 来 生成 正则 表达 式 。 对 于 其 他 验证 格式 ,需要 用 户 自己 编写 正则 表达 式 。 
正则 表达 式 是 由 普通 字符 ,特殊 字符 组 成 的 一 种 字符 模式 , 它 由 正 斜 杠 括 住 。 正 则 表达 
式 的 书写 规范 见 表 3-13。 
表 3-13 ”正则 表达 式 的 书写 规范 


特殊 字符 说 明 m h 
? 表示 0 个 或 1 个 字符 /ab?/ 表 示 aab 
* 表示 0 个 或 多 个 字符 /ab * / 表示 aab abb abbb 等 
¥ 表示 1 个 或 多 个 字符 je ab abb abbb 等 ;/(ab) 十 /表示 ab、abab、 
C] 表示 [ ] 内 的 任 一 个 字符 /[0-9]/ 表示 任 一 个 数字 ;/[ab-]/ 表示 a、b、- 中 的 一 个 


有 两 种 方式 :{n} 表 示 n 个 字符 ; 
{mn} 表 示 m~n 个 字符 


表示 一 个 任意 字符 . {5,10} 表示 5 一 10 个 任意 字符 


/abc{3}/ 表示 abcce;/ Cabe) (3) / 表示 abcabcabc 
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续 表 
特殊 字符 说 明 R A 
o EREE TR FUE 
为 了 提高 可 读 性 
| [ERW 
: A DI rd Mies) Hos] (0) JR A ME EGER 
符号 前 加 上 \ 符 号 ,如 \C \) 
^ [ERSAHRSTHAGR 
$ | 匹配 字符 囊 的 结束 位 轩 
\d | 表示 0~9 中 的 一 个 数字 与 [0-9] 相 同 
IE OU TET 与/[a-zA-20-9]/ 相 同 
注意 : 
COD 在 口中 , 若 “-” 位 于 两 个 字符 之 间 , 则 “-” 作 为 特殊 字符 解释 。 例 如 ,[a-z] 表 示 任 意 
一 个 小 写字 母 。 


(2) 在 {} 中 的 “,” 作 为 特殊 字符 解释 。 例 如 ,. {5,10) 表示 510 个 任意 字符 。 


5. CustomValidator 控件 
CustomValidator 控件 称 为 自 定义 验证 ,允许 用 户 自 定义 验证 规则 。 
CustomValidator 控件 的 声明 格式 如 下 : 


<asp:CustomValidator 


ID= mm 


runat- "server" 


ControlToValidate- "被 验证 控件 的 ID" 
ClientValidationFunction- "窗户 端 验证 函数 " 
OnServerValidate- "服务 器 端 验证 函数 " 
ErrorMessage= "验证 失败 时 显示 的 错误 信息 "/> 


OnServerValidate 二 "服务 器 端 验 证 函数 ": 当 CustomValidator 控件 被 调用 时 会 触发 
该 事件 ,事件 参数 为 ServerValidateEventArgs, 含 有 两 个 属性 。 

(1) Value: 返回 被 验证 的 控件 的 Value( 或 Text) 值 。 

(2) IsValid: 判断 被 验证 的 控件 是 否 验证 成 功 , 若 为 False, 则 显示 错误 信息 。 

【 例 3-29】 CustomValidator 控件 的 服务 器 端 验证 ,设计 界面 如 图 3-32 Bron o 


332 ”服务 器 端 验证 


CD 在 站 点 中 添加 一 个 名 称 为 CustomValidatorl. aspx 的 网 页 。 
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(2) 向 网 页 中 添加 一 些 控件 ,并 设置 属性 , 见 表 3-14. 
X314 例 3-29 控件 的 属性 设置 


控件 类 型 ID 属性 设置 
TextBox Num 
ControlToValidate— "Num" 
CustomValidator CustomValidatorl OnServerValidate— "CheckNum" 
ErrorMessage 一 "您 输入 的 数字 不 是 偶数 " 
Button Bl Text 二 "确定 " 


G) 在 .cs 文件 中 编写 代码 : 


void Page Load (Object sender, EventArgs e) 
( Response.Write (Num.Text); ) 
protected void CheckNum(object source, ServerValidateEventArgs e) 
( 
// 当 e.IsValid Jj False 时 显示 错误 信息 
e.IsValid-int.Parse(e.Value)$2--0; 
) 


程序 说 明 : 当 在 文本 框 中 输入 一 个 奇数 ,如 5 ,并 单 击 “确定 ”按钮 时 ,会 先 输出 5, 再 显 
示 错 误 信息 ,表明 服务 器 端 验证 是 在 调用 Page_Load() 函 数 之 后 进行 的 。 
【 例 3-30】 CustomValidator 控件 的 客户 端 验证 ,设计 界面 如 图 3-33 所 示 。 


图 3-33 客户 端 验证 


CD 在 站 点 中 添加 一 个 名 称 为 CustomValidator2. aspx 的 网 页 。 
(2) 向 网 页 中 添加 一 些 控 件 , 并 设置 属性 , 见 表 3-15。 
表 3-15 例 3-30 控件 的 属性 设置 


控件 类 型 ID 属性 设置 
TextBox Num 
ControlToValidate— "Num" 
CustomValidator CustomValidatorl ClientValidationFunction— "CheckNum" 
ErrorMessage 一 "您 输入 的 数字 不 是 偶数 " 
Button Bl Text 二 "确定 " 


(3) Æ. aspx JULI <head> fI — / head Z^ [B] 4i 5 JavaScript Jl As : 


Script language- "JavaScript"» 
function CheckNum (source, arguments) 
t 
arguments.IsValid- Number (arguments.Value)$2--0; 
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} 
</script> 


(D 在 . cs 文件 中 编写 代码 : 


protected void Page Load(object sender, EventArgs e) 
t 

Response.Write (Num. Text) ; 
) 


程序 说 明 : 当 在 文本 框 中 输入 一 个 奇数 ,如 5 ,并 单 击 “确定 ?按钮 时 , 仅 显 示 错 误 信息 ， 
表明 客户 端 验证 是 在 客户 端 执行 单 击 事件 时 就 调用 验证 控件 了 。 


6. ValidationSummary 控件 
ValidationSummary 控件 称 为 验证 汇总 ,用 来 显示 网 页 上 所 有 验证 控件 的 错误 信息 。 
ValidationSummary 控件 的 声明 格式 如 下 : 


«asp:Validationsummary 

ID= "en" 

runat="server" 

DisplayMode- "BulletList|List|SingleParagraph" 
ShowSunmary- "true|false" 

ShowMessageBox- "true | false" 

HeaderText- "标题 文字 "/> 


其 中 ,DisplayMode 属性 用 于 设置 出 错 信息 的 显示 模 


T 1 

式 ,可 以 取 如 下 几 个 值 。 p" E ta | 
(1) BulletList; 默认 的 显示 模式 ,分 行 显示 出 错 | | 

as £z: EHE AN GE EL i fiza] | 
信息 ,每 行 信息 前 加 一 个 点 号 。 m 
(2) Lis 分 行 显示 出 错 信息 ,每 行 信息 前 不 加 E 

点 号 | 错误 信息 1 
FR. 1| e 错误 信息 2 1 
(3) SingleParagraph: 以 单行 形式 显示 所 有 出 错 i j i 

1 [Message 1 

信息 。 aru RE ! 


[B] 3-31]  ValidationSummary 控件 的 应 用 , 设 图 3-34 ValidationSummary 控件 的 应 用 
计 界 面 如 图 3-34 所 示 。 
(1) 在 站 点 中 添加 一 个 名 称 为 ValidationSummary. aspx 的 网 页 。 
(2) 向 网 页 中 添加 一 些 控件 ,并 设置 属性 , 见 表 3-16. 
X316 例 3-31 控件 的 属性 设置 
控件 类 型 ID 属性 设置 


TextBox Name 


ControlToValidate— "Name" Display — "None" 


RequiredField Valid; R1 
a FO Ee ErrorMessage 一 "姓名 字段 不 可 空白 " 


TextBox Score 
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续 表 
控件 类 型 ID 属性 设置 


ControlToValidate— "Score" Display— "None" 
ErrorMessage— "成 绩 字 段 不 可 空白 " 


RequiredFieldValidator R2 


ControlToValidate— "Score" 
MaximumValue— "100" MinimumValue— "0" 


li R 
RangeValidator 3 Type- "Integer" Display "None" 
ErrorMessage— "R VMF 0 一 100 分 之 间 " 
Button Bl Text 二 "确定 " 
F Mode=" Pe 
ValidationSummary vı DisplayMode—" BuilletList 


ShowSummary="True" HeaderText= "错误 警告 " 


(3) 在 .cs 文件 中 编写 代码 ; 


protected void Page Load (object sender, EventArgs e) 
{ 
if (Page.IsPostBack) Response.Write ("OK"); 
) 
protected void Bl Click(object sender, EventArgs e) 
{ 
if (Page.IsValid) Message.Text- "全 部 栏 位 验证 成 功 "; 
) 


小 结 
(OD 验证 控件 允许 采用 服务 器 验证 和 客户 端 验证 两 种 方式 。 
(D 服务 器 验证 : 指 在 上 传 数据 并 调用 Page_Load() 函 数 后 才 调 用 验证 控件 ,所 有 验证 


控件 均 支 持 此 方式 。 


© 客户 端 验 证 : 指 在 客户 端 执行 单 击 事件 时 就 调用 验证 控件 ,所 有 验证 控件 均 支 持 此 


方式 , 自 定 义 验 证 当 包 含 ClientValidationFunction 王 "函数 名 "时 也 支持 此 方式 。 


(2) 第 一 次 加 载 网 页 时 没有 调用 验证 控件 。 
G) 在 页 面包 含 验 证 控件 的 情况 下 ,不 管 哪 类 服务 器 控件 ,只 要 存在 OnServerClick = 


"函数 名 "( 或 OnClick 二 "函数 名 "), 则 单 击 控件 时 ,就 会 进行 如 下 6 项 操作 。 


O 客户 端 验 证 。 

@ 调用 本 页 面 的 用 户 界 面部 分 。 

© 将 客户 端 各 控件 的 主要 属性 值 (Value、Text、Checked、PostFile) 上 传 到 服务 器 。 
(D 调用 Page_Load() 函 数 。 

© 服务 器 验证 。 

© 执行 指定 的 函数 。 


3.4.3 验证 控件 的 综合 应 用 


【 例 3-32】 验证 控件 的 综合 应 用 ,设计 界面 如 图 3-35 所 示 。 
(1) 在 站 点 中 添加 一 个 名 称 为 login. aspx 的 网 页 。 
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用 户 名 (9 BERAGSPE) 

ZBO EAH 

确认 密码 (9 HERESUGER PRENT 
TAIG 

学 历 (9 TERIS 

出生 年 有 0 ep e EE 
电子 邮箱 POOO EAE 
zett P | 


3-35 ”验证 控件 的 综合 应 用 


D 向 网 页 中 添加 控件 ,并 设置 属性 , 见 表 3-17。 


表 3-17 例 3-32 控件 的 属性 设置 


控件 类 型 ID 属性 设置 
TextBox TextBoxl 
RequiredPield- R1 ControlToValidate— "TextBoxl" ErrorMessage= "if 58i A MP 4" 
Validator 
TextBox TextBox2 
Requiediueld- R2 ControlToValidate— "TextBox2" ErrorMessage— "ifj fi A 8E 83 " 
Validator 
TextBox TextBox3 | TextMode— "Password" 
RequiredField- R3 ControlToValidate = " TextBox3" Display = " Dynamic" ErrorMessage = 
Validator "请 重复 输入 密码 " 
C Validat cl ControlToCompare = " TextBox2" ControlToValidate = " TextBox3" 
ompareValidator 
ErrorMessage 一 "两 次 密码 不 一 致 " Operator "Equal" Type 一 "String" 
ee R4 FepessDureetipdr- Horizontal" RepeatLayout — "Flow" TextAlign— 
right 
Kegnedbield- R5 ControlToValidate— "R4" ErrorMessage— "请 选择 性 别 " 
Validator 
DropDownList Di 包含 “中 职 "“ 大 专 "“ 本 科 ”“ 硕 士 >"“ 博 士 5 个 选项 
r R6 ControlToValidate="D1" ErrorMessage 二 "请 选择 学 历 " 
Validator 
TextBox TextBox4 
RequiredField- R7 ControlToValidate = " TextBox4" Display — " Dynamic" ErrorMessage = 
Validator "请 输入 出 生年 月 " 
RegularExpression- "-— ControlToValidate— " TextBox4" ErrorMessage— " tH E F H RATE 
Validator eguan é| 3t" ValidationExpression— "MVd(4)-C1[0-2]l [1-9] [01-9 " 
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续 表 
控件 类 型 ID 属性 设置 
TextBox TextBox5 
RequiredField- m Control To Validate = " TextBox5" Display =" Dynamic" ErrorMessage = 
Validator "请 输入 Email" 


ControlToValidate— " TextBox5" ErrorMessage — " Email 格式 不 正 


RegularE: i 
n emu Regular2 m" ValidationExpression— "[Vw— ]+@[\w—]+. Ccom| net|org| 
Validator zin 
edu| mil)" 
TextBox TextBox6 
Button Buttonl Text= "提交 " 


G) 在 .cs 文件 中 编写 代码 : 


protected void Page Load(object sender, EventArgs e) 
{ 

if (Page.IsPostBack) Labell.Text- "祝贺 你 提交 成 功 !"; 
) 


35 项 目 实 训 


实 训 1 应 用 HTML 控件 


实 训 目的 

(1) 掌握 HtmlInputText 控件 的 应 用 。 

(2) 掌握 HtmlInputRadioButton 控件 的 应 用 。 

(3) 掌握 HtmlSelect 控件 的 应 用 。 

(4) 掌握 HtmlInputCheckBox 控件 的 应 用 。 

(5) 掌握 HtmlInputButton 控件 的 应 用 。 

RIER 

(1) 创建 一 个 Web 网 站 sx03 ,并 设置 成 虚拟 目录 。 

(2) 在 网 站 中 添加 一 个 名 为 sx3_1. aspx 的 网 页 ,用 HTML 控件 编写 一 个 简单 的 注册 
页 面 , 单 击 “ 确 定 ” 按 钮 后 ,显示 注册 人 员 的 综合 信息 ,运行 界面 如 图 3-36 所 示 。 


实 训 2 应 用 Web 控件 


实 训 目 的 

(1) 掌握 TextBox 控件 的 应 用 。 

(2) 掌握 RadioButtonList 控件 的 应 用 。 

(3) 掌握 在 DropDownList 控件 中 动态 设置 选项 的 方法 。 

(4) 掌握 CheckBoxList 控件 的 应 用 。 

实 训 要 求 

在 网 站 中 添加 一 个 名 称 为 sx3_2. aspx 的 网 页 ,用 Web 控件 编写 一 个 简单 的 注册 页 面 ， 
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单 击 “ 确 定 ” 按 钮 后 ,显示 注册 人 员 的 综合 信息 ,初始 界面 如 图 3-37 所 示 ,运行 界面 如 图 3-36 
所 示 。 要 求 “籍贯 ”下 拉 框 中 包含 “湖南”“ 湖 北 ”"“ 广 东 ”“ 广 西 "“ 北 京 "“ 天 津 "“ 上 海 ” 
7 个 选项 , 且 7 个 选项 是 在 Page_Load() 函 数 中 设置 的 。 


要 无 标题 页 - 了 crosoft Internet Explorer — [- |D)R] 
i xit REO 查看 WW KRW IAV Eo Q 


O~- O 3 (d Q sr wrar 


P BE QD [d] http://1ocalhost:1050/aspNet1/HtalRegi ster M| EJ #5 


， 男 ,湖南 人 ， 业 余 爱 好 ， 书法， 体育 ， 音 乐 ， 


=o 
68 Ok 
LES ! 65 oZ 
业余 爱好 ， 口 文学 回 书法 回 体育 ERA 一 
EXSDSEDEREERS 
EJ Fih Intranet m 
图 3-36 SD 1 运行 界面 图 3-37 实 训 2 初始 界面 


实 训 提示 

(1) RadioButtonList 控件 、CheckBoxList 控件 的 RepeatDirection 属性 要 设置 为 
Horizontal, RepeatLayout 属性 要 设置 为 Flow。 

(2) 参考 程序 代码 如 下 : 


protected void Page Load(object sender, EventArgs e) 
t 
String[] jg- ( "lm ", "Bde", "广东 ", "广西 ", "北京 ", "RÆ", "上海" y; 
DropDownListl.DataSource- jg; 
DropDownListl.DataBind(); 
} 
protected void Buttonl Click (object sender, EventArgs e) 
{ 
String s-""; 
S*- TextBoxl.Text* ","; 
S* - RadioButtonListl.SelectedValue* ", "; 
s*- DropDowunListl.SelectedValue- "Å , "; 
st=" 业 余 爱 好 : "; 


for (int i=0; i«CheckBoxListl.Items.Count; i++) 
{ 
if (CheckBoxListl.Items[i].Selected) 
S- s* CheckBoxListl.Items[i].Value-*","; 
} 
Response.Write (s); 
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实 训 3 应 用 验证 控件 


实 训 目 的 

(1) 掌握 RequiredFieldValidator 控件 的 应 用 。 

(2) 掌握 CompareValidator 控件 的 应 用 。 

(3) 掌握 RangeValidator 控件 的 应 用 。 

(4) 掌握 RegularExpressionValidator 控件 的 应 用 。 
(5) 掌握 CustomValidator 控件 的 应 用 。 


实 训 要 求 


CD 在 网 站 中 添加 一 个 名 称 为 sx3_3. aspx 的 网 页 ,初始 界面 如 图 3-38 所 示 , 各 验证 控 
件 的 类 型 见 表 3-18。 


FRANE) 
APREA 失学 成 三 必须 在 400~900 之 间 P 


邮政 编码 BERETES BETE BIER 
图 
图 3-38 实 训 3 初始 界面 
X318 验证 控件 的 类 型 
被 验证 控件 验证 控件 验证 失败 时 显示 的 错误 信息 

TextBoxl 必需 字段 验证 姓名 不 能 为 空 
RadioButtonListl | 必需 字段 验证 性 别 不 能 为 空 
TextBox2 必需 字段 验证 ,用 户 自 定义 验证 | 出 生日 期 不 能 为 空 ,日 期 格式 必须 为 yyyy-mm-dd 
TextBox3 必需 字段 验证 .比较 验证 入 学 日 期 不 能 为 空 ,入 学 日 期 必须 大 于 出 生日 期 
TextBox 必需 字段 验证 、 范 围 验证 Er 
TextBox5 必需 字段 验证 \ 正 则 表达 式 验 证 | 邮政 编码 不 能 为 空 ,非法 邮政 编码 


(2) 车 验证 成 功 , 则 在 网 页 中 显示 “你 成 功 提交 ,恭喜 !”。 
实 训 提示 
验证 出 生日 期 的 JavaScript 函数 如 下 : 


«script language- "JavaScript"> 
function CheckNum (source, arguments) 
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var sDate- arguments.Value; 
var re- /^[0- 9- ]« $ /; 

// 正 则 表达 式 , [0- 9- ] 匹 配 一 个 数字 或 -号 , [0- 9- ]+ 匹 配 由 数字 与 -号 组 成 的 字符 串 
if(!re.test(sDate)) arguments.IsValid- false; 


var flag- false; 
var Days- new Array (31,28, 31, 30, 31, 30, 31,31, 30, 31, 30, 31) ; 
var year, month, day; 
// 以 -为 分 隔 符 , 将 spate 分 成 若干 个 字符 串 ,并 将 各 字符 串 依次 存 人 数组 iapate 中 
iaDate-sDate.split("-"); 
if (iaDate.length !-3) flag-true; 
else 
{ if (iaDate[0] .length!- 4|| iaDate[1] .length» 2]| iaDate[2] .length» 2) flag-true; 
year- parseFloat (iaDate[0]); 
month- parseFloat (iaDate[1]) ; 
day-parseFloat (iaDate[2]) ; 
IFE 2 RS 28 X, HE 2 HO 29 X 
if (((year $4--0) && (year $100 !—0)) || (year $400==0)) Days[1]-29; 
if (month«l||month» 12) flag-true; 
if (day«1||day» Days [month- 1]) flag-true; 
} 
if (flag--true)arguments.IsValid- false; 
) 


</script> 
思考 与 练习 
一 、 填 空 题 
1. ASP. NET 将 用 户 界 面 和 程序 代码 进行 彻底 分 离 ,并 分 别 放 在 不 同 的 文件 中 。 用 户 
界面 放 在 文件 中 ,程序 代码 放 在 文件 中 。 
2. 在 ASP.NET 中 ,服务 器 控件 包括 控件 、 控件 、 控件 、 
控件 。 
3. 为 了 使 某 些 RadioButton 控件 构成 群 组 关系 ,必须 为 每 个 RadioButton 控件 的 
属性 赋予 相同 的 值 。 
4. 当 TextBox 服务 器 控件 的 属性 被 设置 为 True 时 ,使 用 Enter 键 或 Tab 键 
跳出 文本 输入 框 时 ,将 自动 触发 OnTextChanged 事件 。 
5. 要 验证 是 否 有 数据 输入 ,应 使 用 控件 ,要 限制 输入 的 数据 在 某 一 范围 内 ,应 
使 用 控件 。 
6. 在 使 用 AdRotator 控件 之 前 ,必须 定义 一 个 格式 的 广告 文件 。 


7. 腾讯 QQ 号 从 10000 开始 ,匹配 腾讯 QQ 号 码 的 正则 表达 式 可 表示 为 
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二 、 编 程 题 

1. 编写 一 个 程序 ,要 求 使 用 RadioButtonList 控件 控制 字体 是 否 为 斜体 ,CheckBox 控 
件 控制 是 否 为 粗 体 ,DropDownList 控件 控制 字体 大 小 ,Button 控件 执行 过 程 ,Label 控件 显 

2. 设计 一 个 Web 登录 页 面 ,要 求 使 用 RegularExpressionValidator 控件 来 保证 用 户 输 
入 的 电子 邮件 格式 中 @ 后 面 只 能 是 126. com ,163. com .sohu. com, 


zx 
— ASP. NET 内 置 对 象 


ASP. NET 提供 了 一 些 内 置 对 象 ,通过 这 些 对 象 可 以 设置 Web 页 的 有 关 属 性 和 方法 ， 
也 可 以 实现 基本 的 请 求 , 响 应 .会 话 以 及 共享 等 处 理 功能 。 本 章 将 介绍 ASP. NET 中 几 个 
常用 的 内 置 对 象 ,主要 有 Page X1 4. Response X% , Request 对 象 、Application 对 象 、 
Session 对 象 和 Server 对 象 。 


zanak 


* 掌握 Page 对 象 的 属性 ,方法 和 事件 
。 掌握 Response 对 象 的 属性 和 方法 

。 掌握 Request 对 象 的 属性 和 方法 

* 掌握 Application 对 象 的 属性 和 方法 
。 掌握 Session 对 象 的 属性 和 方法 

。 掌握 Server 对 象 的 属性 和 方法 


41 Page 对 象 


4.1.1 Page 对 象 的 属性 
ASP. NET 中 的 每 个 . aspx 页 面 在 运行 时 都 将 被 编译 为 Page 对 象 ,并 缓存 在 服务 器 内 
存 中 。Page 对 象 是 由 System. Web. UI 命名 空间 下 的 Page 类 派生 来 的 。Page 对 象 的 常用 
属性 见 表 4-1, 
表 4-1 Page 对 象 的 常用 属性 


属 性 说 9 
用 来 判断 网 页 在 何 种 情况 下 加 载 , 若 取 false 表示 第 一 次 加 载 网 页 ， 
IsPostBack ER true 表示 客户 端 上 传 数据 时 加 载 网 页 。 此 属性 是 Page 对 象 所 


独 有 的 ,通常 与 Page_Load 事件 配合 使 用 


用 来 判断 页 面 上 的 验证 控件 是 否 全 部 验证 成 功 , 若 有 一 个 验证 控件 
验证 失败 , 则 返回 false 


EnableViewState 设置 网 页 是 否 保持 视图 状态 ,默认 为 true 
Visible 获取 或 设置 网 页 是 否 可 见 


IsValid 
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续 表 
属 wu 说 9 
Response 获取 与 Page 关联 的 HttpResponse 对 象 
Request 获取 请 求 页 面 的 HttpRequest 对 象 
Application 为 当前 Web 请 求 获取 Application 对 象 
Session 获取 ASP. NET 提供 的 当前 Session 对 象 
Server 获取 与 Page 关联 的 Server 对 象 


很 容易 看 出 , Page 对 象 的 一 些 属 性 本 身 就 是 ASP. NET 的 内 置 对 象 ,如 Response, 
Request, Application, Session 和 Server, 它 们 驻 留 在 Web 服务 器 中 。 

(1) Response 对 象 : 响应 客户 端的 请 求 ,并 将 响应 结果 返回 给 客户 端 。 

(2) Request 对 象 : 接收 从 客户 端 传送 到 服务 器 的 信息 。 

(3) Application 对 象 : 记录 所 有 上 线 用 户 均 共享 的 信息 ,Application 对 象 随 着 Web 服 
务 器 的 启动 而 产生 , 随 着 Web 服务 器 的 关闭 而 终止 。 

(4) Session 对 象 : 记录 每 个 上 线 用 户 独 享 的 信息 ,Session 对 象 随 着 用 户 的 上 线 而 产 
生 , 随 着 用 户 的 下 线 或 强制 解除 而 终止 。 

(5) Server 对 象 : 执行 与 Web 服务 器 直接 相关 的 一 些 操作 , 它 包 含 几 个 重要 的 方法 ， 
Server 对 象 的 功能 主要 通过 这 些 方法 体现 。 


4.1.2. Page 对 象 的 事件 
所 谓 事件 ,就 是 外 界 对 对 象 所 实施 的 动作 。Page 对 象 的 常用 事件 见 表 4-2。 
表 4-2 Page 对 象 的 事件 


事 A 说 明 
Init 页 面 初始 化 会 触发 此 事件 ,是 网 页 执行 时 第 一 个 被 触发 的 事件 
Prelnit 页 面 初始 化 开始 触发 此 事件 
InitComplete 页 面 初始 化 完成 触发 此 事件 
Load 页 面 被 加 载 时 触发 此 事件 
PreLoad 在 Load 事件 之 前 触发 此 事件 
PreRender 在 页 面 加 载 控件 对 象 之 后 .呈现 之 前 触发 此 事件 
PreRenderComplete | 在 呈现 页 面 之 前 触发 此 事件 
Unload 当 服 务 器 控件 从 内 存 中 印 载 时 触发 此 事件 
Disposed 当 从 内 存 释放 服务 器 控件 时 触发 此 事件 
Error -a SIME 自 定义 错误 处 理 


其 中 ,Init 是 第 一 次 加 载 网 页 时 才 会 触发 的 事件 ;Load 是 每 次 加 载 网 页 时 都 会 触发 的 
事件 ,通过 IsPostBack 属性 值 可 以 判断 出 网 页 是 首次 加 载 还 是 客户 端 上 传 数据 时 才 加 
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载 的 。 对 无 标题 页 - Jicrosoft I.. | 


【 例 4-1】 在 站 点 中 添加 一 个 名 称 为 Event. aspx W | X*9 ssw sav sme 


LE) [B http://iocahest:z02/ 国 


网 页 ,运行 界面 如 图 4-1 所 示 。 


Event. aspx. cs 文件 的 程序 代码 如 下 : SUM 
发 生 Page_Load 事 件 
protected void Page Init (object sender, EventArgs e) D 16:26:34 


{ 
Labell.Text- "发 生 Page In 让 事件 "+ System. DateTime. e 
Now.ToLongTimeString () ; 


图 4-1 Page 对象 的 事件 
} 
protected void Page Load (object sender, EventArgs e) 
{ 
Label2.Text+=" 发 生 Page Load 事 件 <br>"; 
DateTime MyDateTime- System.DateTime.Now; 
Label2.Text+=" 现 在 是 :"+MyDateTime.ToLongTimeString()+"<br>"; 
int hou; 
String str=""; 
hou= Convert .ToInt32 (MyDateTime.Hour)/ 6; 
switch (hou) 
{ 
case 0: str=" 早 上 好 ";break; 
case 1: str=" 上 午 好 ";break; 
case 2: str=" 下 午 好 ";break; 
case 3: str- "晚上 好 "7breaky 
) 
Label2.Text*- str; 
) 


程序 说 明 : 

(1) System. DateTime. Now: 返回 系统 日 期 \ 时 间 , 它 是 一 个 对 象 ,含有 Date, Hour, 
Minute, Second, Year, Month, Day, DayOfWeek 等 属性 , 例如 ,System. DateTime. Now. 
DayOfWeek 返回 星期 几 。 

(2) 设 x Jj DateTime 类 型 , 则 : 

(D x. ToShortDateStringO : 返回 “yyyy-mm-dd”。 

© x. ToLongDateStringO : 返回 “yyyy 年 mm H dd H”. 

@ x. ToLongTimeStringO : 返回 “hh: mm: ss”. 

(D x. ToShortTimeStringO ; 返回 “hh: mm", 


4.2 Response XJ $& 


Response 对 象 提供 对 当前 页 面 的 输出 流 的 访问 ,可 以 向 客户 端 浏 览 器 发 送信 息 ,或 者 
将 访问 者 导航 到 另 一 个 网 址 ,并 可 以 输出 和 控制 Cookie 信息 等 。 
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4.2.1 Response 对 象 的 属性 
Response 对 象 是 HttpResponse 类 的 一 个 对 象 ,与 一 个 HTTP 响应 相对 应 。 每 次 客户 
端 发 出 一 个 请 求 的 时 候 ,服务 器 就 会 用 一 个 响应 对 象 来 处 理 这 个 请 求 ,处 理 完 这 个 请 求 之 
后 ,服务 器 就 会 销毁 这 个 响应 对 象 ,以 便 继续 接受 其 他 客户 端 请 求 。 
Response 常用 属性 见 表 4-3。 
表 4-3 Response 对 象 的 属性 


属 wu 说 å 

设置 服务 器 端 是 否 将 页 面 先 输出 到 缓冲 区 中 ,默认 值 为 false。 当 取 

Buffer 值 为 ture 时 ,服务 器 端 先 将 页 面 输出 到 缓冲 区 中 ,然后 再 从 缓冲 区 中 
输出 到 客户 端 浏览 器 ,否则 直接 将 信息 输出 到 客户 端 浏览 器 

Charset 获取 或 设置 字符 编码 方式 

ContentType 获取 或 设置 输出 流 的 HTTP 内 容 类 型 ,默认 为 text/html 

ContentEncoding 获取 或 设置 输出 数据 的 HTTP 字符 集 

Cookies 获取 服务 器 发 送 到 客户 端的 Cookie 集合 

Output 返回 输出 HTTP 响应 流 的 文本 输出 

RedirectLocation 将 当前 请 求 重 定向 


4.2.2 Response 对 象 的 方法 


Response 对 象 用 来 控制 输出 到 客户 端的 信息 ,常用 方法 见 表 4-4。 
表 4-4 Response 对象 的 方法 


方 ”法 说 明 
Write( 表 达 式 ) 将 表达 式 的 值 发 送 到 客户 端 
WriteFile(" 文 件 名 ") 将 指定 文件 的 内 容 发 送 到 客户 端 
Redirect(" 网 页 文件 ") 将 客户 端 重新 定向 到 指定 的 网 页 文件 
ClearContent() 清空 存放 在 缓冲 区 中 尚未 发 送 到 客户 端的 所 有 内 容 
End() 结束 . aspx 页 面 的 执行 ,并 且 将 缓冲 区 中 的 内 容 发 送 到 客户 端 
CloseO 关闭 与 客户 端的 连接 


【 例 4-2] 使 用 Response. WriteFile 方法 将 文本 文件 exa. xls 的 内 容 发 送 到 客户 端 ,如 
图 4-2 所 示 。 程 序 代 码 如 下 : 


protected void Page Load(object sender, EventArgs e) 

{ 
Response.ContentType- "Application/Vnd.MS- Excel"; 
Response.WriteFile ("exa.xls"); 
Response.End() ; 
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Z http://localhost:2024/chap04/Response/¥rit.-. [- |@| 区 | 
i 文件 和 SO WE AD 格式 0) IAV EE" Q 


|Q«.O-38 OP» ium 9" 


A) http://localhost:2024/chap04/Response/iri teFile. «| EJ 9831 


图 4-2 ”使 用 Response 对 象 打开 Excel 文件 


【 例 4-3] 使 用 Response. Redirect 方法 完成 页 面 重新 定位 。 


protected void Page Load(object sender, EventArgs e) 
{ 
Response.Redi rect ("http: / /www.163.com") ; 


43 Request 对 象 


服务 器 端 经 常 需要 获得 客户 端 输入 的 信息 ,比如 通常 通过 让 用 户 注册 ,获取 客户 端 用 户 
提交 的 表单 数据 等 。 利 用 ASP. NET 提供 的 Request 对 象 就 可 以 轻松 地 取得 客户 端的 


4.3.1 Request 对 象 的 属性 


Request 对 象 实际 上 操作 System. Web 命名 空间 中 的 HttpRequest 类 。 当 客户 端 发 出 
请 求 执行 ASP. NET 程序 时 ,客户 端的 请 求 信 息 ,包括 请 求 报头 、 客 户 端的 机 器 信息 、 客 户 
端 浏览 器 信息 .请求 方法 (如 Post, Get) ,提交 的 窗 体 信息 等 ,会 被 包装 在 Request 对 象 中 。 
Request 对 象 的 属性 比较 多 ,常用 属性 见 表 4-5。 


表 4-5 Request 对 象 的 常用 属性 


m t 说 明 
ApplicationPath 返回 当前 页 面 所 在 的 站 点 的 名 称 
PhysicalApplicationPath 返回 当前 页 面 所 在 的 站 点 的 绝对 路 径 
Browser 有 关 正 在 请 求 的 客户 端的 浏览 器 功能 的 信息 
Cookies 取得 从 客户 端 发 送 的 Cookie 的 集合 
Form 取得 从 客户 端 以 Post 方式 传送 过 来 的 各 控件 的 值 
QueryString 取得 从 客户 端 以 Get 方式 传送 过 来 的 各 控件 的 值 
ServerVariables 获取 Web 服务 器 变量 的 集合 
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续 表 
属 人 性 说 å 
Params Form、QueryString、ServerVariables 和 Cookies 集合 的 统称 
FilePath 获取 当前 请 求 的 虚拟 路 径 
Files 获取 客户 端 下 载 的 文件 集合 
RequestType 获取 或 设置 客户 端 使 用 的 HTTP 数据 传输 方式 (Get 或 Post) 
Url 获取 有 关 当 前 请 求 的 URL 的 信息 
UserLanguages 获取 客户 端 主机 所 使 用 的 语言 
UserHostAddress 获取 客户 端 主机 的 TP 地 址 


其 中 ,属性 Form, QueryString, ServerVariables, Params, Cookies 又 称 为 集合 ,采用 不 
同 的 Request 对 象 获取 方法 可 以 获取 不 同 集合 中 的 信息 。 


4.3.2 Request 对 象 的 应 用 


表单 数据 返回 服务 器 端的 方式 有 Get 和 Post 两 种 ,默认 为 Post 方式 。 在 Request 对 
象 中 ,采用 Get 方式 提交 的 数据 是 通过 QueryString 集合 实现 的 ,而 采用 Post 方式 提交 的 
数据 是 通过 Form 集合 实现 的 。 


1. Form 集合 
格式 如 下 : 


变量 名 =Request .Form[" 控 件 标识 "] 

功能 : 取得 从 客户 端 以 Post 方式 传送 过 来 的 各 控件 的 Value( 或 Text) 值 。 

【 例 4-4】 在 站 点 中 添加 一 个 名 称 为 Form. aspx 的 网 页 ,运行 界面 如 图 4-3 所 示 。 当 
单 击 “ 确 定 ” 按 钮 时 ,就 会 在 标签 中 显示 提交 的 信息 。 


号 无 标题 页 ~ Microsoft Internet Explorer ”旋回 | 区 
i XQ) SEO SEV KEW TRO 帮助 0D [2 


imi 


A) http://localhost: 1824/chap04/Request/Forn. [| EJ 968. 
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姓名 


性 别 


学 历 


系 别 


学 历 ， 大专 
系 别 ，CS 


4-3 Request. Form 集合 的 应 用 


在 .cs 文件 中 编写 如 下 代码 : 
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protected void Page Load(object sender, EventArgs e) 


t 
if (Page.IsPostBack) 
t 


Labell.Text- "E Ji] : " Request .Form["RadioButtonListl"]-* "<br>"; 
Label1.Text+=" 学 历 : "- Request. Form["D1"] « "<br>"; 
Labell.Texte- "f 9l : "Request .Form["T2"] ; 


10. ) 


Ls 

2 

3 

4 

5. Labell.Text- "姓名 : "« Request.Form["T1"]- "<br>"; 
6 

7 

8 

9 


如 果 把 “确定 ”按钮 的 PostBackUrl 属性 设置 为 Forml. aspx', 并 且 在 站 点 中 再 添加 一 个 名 
称 为 Forml. aspx 的 网 页 ,把 Form. aspx 网 页 中 的 Page_Load 函数 体 ( 即 第 3 一 9 行 ) 移 动 到 
Forml. aspx 网 页 的 Page Load 函数 中 ,这 样 ,就 能 将 一 个 网 页 的 数据 提交 到 另 一 个 网 页 中 了 。 


2. QueryString 集合 
格式 1: 


变量 名 =Request .Querystring[" 控 件 标 识 "] 


功能 : 取得 从 客户 端 以 Get 方式 传送 过 来 的 各 控件 的 Value( 或 Text) 值 。 


格式 2: 
变量 名 =Request .Querystring[" 参 数 名 称 "] 


功能 ; 取得 从 客户 端 传送 过 来 的 各 参数 的 值 。 
带 参 数 的 语句 如 下 : 


CD 带 参 数 超 链接 <a href= "aspx 文件 名 ?参数 名 二 值 & 8085 — fü" 
(2) Response. Redirect("aspx 文件 名 ? 参数 名 = 值 & 参数 名 一 值 "); 
[514-5] 在 站 点 中 添加 名 称 分 别 为 2a. aspx 和 2b. aspx 的 两 个 网 页 。 


(1) 2a. aspx 页 面 的 初始 界面 如 图 4-4 所 示 ， 
其 中 HyperLink 控件 的 NavigateUrl 属性 设置 为 
“2b. aspx? no— 1 name— 3K =”, f£ Button 控件 
的 OnClick 事件 所 关联 的 事件 处 理 函 数 中 添加 如 
TAS. 


Response. Redi rect ("2b.aspx? no- 1&name- 3K — ") ; 


| 将 no=lname=' 张 三 从 2a aspx 传 递 到 2b aspx 的 方式 : 
1 使 用 文件 超 链接 ， 
2 使 用 Response Redirect 方法 : 


图 4-4 2a. aspx 的 初始 界面 


(2) 在 2b. aspx 页 面 中 添加 一 个 Button 控件 ,将 Button 控件 的 PostBackUrl 属性 设置 
为 2a. aspx, Text 属性 设置 为 “返回 ”。 在 2b. aspx. cs 文件 中 编写 代码 : 


protected void Page Load(object sender, EventArgs e) 


t 
String no- Request .QueryString["no"]; 
String name- Request .QueryString |["name"] ; 
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Response.Write ("f E :" no+ ", 姓 名 :"+name); 
H 
单 击 2a. aspx 页面 的 超 链接 或 按钮 ,就 会 切换 到 2b. aspx 页 
面 ,运行 结果 如 图 4-5 所 示 。 当 单 击 “ 返 回 ” 按 钮 时 ,就 会 返回 到 
2a. aspx 页 面 。 


3. ServerVariables 集合 

有 时 候 需要 获得 服务 器 端 或 客户 端的 一 些 信息 ,比如 TP 地 
址 ,浏览 器 类 型 等 ,这 些 信息 包含 在 HTTP 头 部 中 随 HTTP 请 求 一 起 传送 , 可 使 用 
ServerVariables 集合 获取 这 些 信息 。 

格式 如 下 : 


Request. ServerVariables[" 服 务 器 环境 变量 "] 


功能 : 获取 服务 器 端 环境 变量 的 值 。 
常用 的 服务 器 端 环境 变量 见 表 4-6。 


表 4-6 常用 的 服务 器 端 环境 变量 


图 4-5 2b. aspx 的 运行 界面 


环境 变量 名 称 说 9 
ALL HTTP 客户 端 发 送 的 所 有 HTTP 标题 文件 
CONTENT_LENGTH 获取 请 求 程序 所 发 送 内 容 的 字符 总 数 
CONTENT_TYPE 获取 发 送 内 容 的 数据 类 型 
LOCAL_ADDR 获取 服务 器 的 TP 地 址 
REMOTE_ADDR 获取 用 户 的 IP 地 址 
PATH_INFO 获取 当前 页 面 的 虚拟 路 径 
URL 获取 当前 页 面 的 URL 基 址 
PATH_TRANSLATED 将 虚拟 路 径 转 换 成 物理 路 径 
QUERY STRING 获取 URL 的 附加 信息 
SCRIPT_NAME 获取 当前 程序 的 文件 名 (包含 虚拟 路 径 ) 
SERVER_PROTOCOL 获取 服务 器 遵从 的 协议 及 版 本 号 
SERVER_NAME 获取 服务 器 的 主机 名 .DNS 别名 ,IP 地 址 


4. Params 集合 


Params 集合 是 Form QueryString, ServerVariables 和 Cookies 集合 的 统称 。 不 管 采 


用 何 种 传送 方式 , 均 可 以 使 用 Request. Params [ "名 称 "], H Form, QueryString, 
ServerVariables Cookies 集合 名 可 以 省 略 。 
例 4-4 的 .cs 文件 可 以 简化 为 : 


1. protected void Page Load(object sender, EventArgs e) 
2. 4 
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3 if (Page.IsPostBack) 

4 t 

5 Labell.Text=" 姓 名 : "- Request ["T1"]+ "<br>"; 

6. Iabell.Text+=" 性 别 : "+ Request ["RadioButtonListl"]e "<br>"; 
7 Labell.Text- "f [fj : "* Request ["D1"]+ "<br>"; 

8 Labell.Text-- "f J|: "+ Request ["T2"]; 

9 


注意 : 

(D Request [" 控 件 标识 "]: 数据 被 上 传 后 ,才能 获得 控件 的 Value( 或 Text) 值 。 它 与 
“控件 标识 . Value”“ 控 件 标 识 . Text” 存 在 一 定 的 区 别 。 

(2) Request [" 参 数 名 称 " ] 不 能 写成 “参数 名 称 . Value", 

(3) 若 客 户 端 不 存在 指定 的 控件 标识 (或 参数 名 称 ), 则 Request [" 控 件 标 识 "] 返 回 


null, 
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Web 站 点 事实 上 是 一 个 多 用 户 的 应 用 程序 。 可 以 把 Application 对 象 视 为 公共 场所 中 
的 公告 牌 ,任何 一 个 用 户 写 人 其 中 的 信息 都 可 以 被 其 他 用 户 看 到 。Application 对 象 是 共有 
的 对 象 ,所 有 的 用 户 都 可 以 对 某 个 特定 的 Application 对 象 进行 修改 。 


4.4.1 Application 对 象 的 属性 


Application 对 象 用 于 保存 所 有 浏览 器 均 共 享 的 信息 ,Application 对 象 随 着 Web 服务 
器 的 启动 而 产生 , 随 着 Web 服务 器 的 关闭 而 终止 。 

Application 对 象 最 常用 的 属性 是 Contents, 它 是 一 个 集合 ,包含 一 系列 的 变量 方法， 
表示 其 变量 方法 时 可 以 省 略 Contents 集合 名 。 


1. Application. Contents 集合 的 变量 
(D 定义 Contents 集合 的 变量 : 


Application.Contents[" 变 量 名 "]= 值 


x 


Application[" 变 量 名 "]= 值 

(2) Contents 集合 的 变量 用 于 保留 一 些 共享 信息 。 

(3) Application[ "变量 名 中 的 类 型 为 Object, 若 不 存在 指定 的 变量 名 , 则 Application 
[ "变量 名 "] 返 回 null。 


2. Application. Contents 集合 的 方法 

(D Application. Lock): 锁定 ,禁止 其 他 客户 机 修改 Application. Contents 中 的 
内 容 。 

(2) Application. UnLock(): 解锁 ,允许 其 他 客户 机 修改 Application. Contents 中 的 内 容 。 


95 


96 ASP. NET 网 站 开发 案例 教程 
一 一 


(3) Application. Remove(" 变 量 名 ") : 移 除 Application. Contents 中 指定 名 称 的 变量 。 

(4) Application. RemoveAll() : 移 除 Application. Contents 中 的 全 部 变量 。 

[B 4-6】 在 站 点 中 添加 名 称 分 别 为 la. aspx 和 1b. aspx 的 两 个 网 页 。 首 先 运行 la. 
aspx 网 页 ,向 Application. Contents 中 添加 信息 ,然后 运行 1b. aspx 网 页 ,显示 Application. 
Contents 中 的 信息 。 

(1) la. aspx. cs 的 程序 代码 如 下 : 


protected void Page Load(object sender, EventArgs e) 

{ 
Application.Lock(); 
Application.Contents ["noticel"]- "XU X CI !« br» "; 
Application |["notice2"]- 123; 
Application.Set ("notice3", "汕头 职业 技术 学 院 "); 
Application.UnLock(); 

} 


(2) 1b. aspx. cs 的 程序 代码 如 下 : 


protected void Page Load (object sender, EventArgs e) 
{ 
Object a=Application["noticel"]; 
Object b- Application["notice2"]; 
Object c-Application["notice3"]; 
Response.Write (a+ ""+b+ "4 c); 


4.4.2 Application 对 象 的 应 用 


利用 Application 对 象 可 以 创建 聊天 室 、 网 站 计数 器 等 应 用 程序 。 
【 例 4-7] 利用 Application 对 象 创建 一 个 简易 聊天 室 。 
CD 在 站 点 中 添加 一 个 名 称 为 Chat. aspx 的 网 页 ,其 HTML 代码 如 下 : 


«form id- "forml" runat="server"> 
<asp:TextBox ID- "T1" runat="server" Height- "150px" Rows- "8" TextMode- "MultiLine" Width 
="250px"> 
< /asp:TextBox> 
<p><asp:TextBox ID- "myword" runat- "server" Columns- "30" Width- "247px"» < /asp:TextBox> 
</p> 
<p><asp:Button ID= "Bl" runat="server" Text- "提交 " OnClick-"Bl Click"/>< /p> 
</form> 


(2) 在 Chat. aspx. cs 文件 中 编写 代码 ; 


protected void Bl Click(object sender, EventArgs e) 
t 

String x-myword.Text; 

Application.lLock(); 
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Application["chat"]=Application["chat"]+"\n"+x; 
Tl.Text=Application["chat"] .ToString(); 
Application.UnLock(); 
myword.Text-""; 

} 


(3) 运行 页 面 ,在 文本 框 中 输入 文本 并 单 击 “提交 ”按钮 时 ,就 能 在 多 行文 本 框 中 显示 提 
交 的 结果 ,运行 界面 如 图 4-6 所 示 。 


A WX - Nicrosoft Interne... [- OR) 
i xt emo ZEV mo I” A 
;地址 名) a http://localhost: 1067/ chapd: E| ora 


anarsa. OR 


您 是 第 2 位 访客 


图 4-6 简易 聊天 室 图 4-7 网 站 计数 器 


【 例 4-8]. 利用 Application 对 象 创建 一 个 网 站 计数 器 ,运行 界面 如 图 4-7 所 示 。 用 户 
每 次 打开 该 网 页 或 刷新 该 页 面 时 ,计数 器 都 会 加 1 。 
在 .cs 文件 中 编写 代码 : 


protected void Page Load(object sender, EventArgs e) 
t 
Application.Lock(); 
Application.Contents ["Counter"]- Convert.ToInt32 (application ["Counter"])- 1; 
Application.UnLock|(); 
myCounter.Text- "您 是 第 "+ Application ["Counter"]-" 位 访客 "; 


45 Session 对象 


Session 对 象 是 ASP. NET 中 很 有 特色 的 一 个 对 象 , 用 于 记录 每 个 上 线 用 户 独 享 的 信 
息 。Session 对 象 中 的 信息 只 能 被 用 户 自己 使 用 ,而 不 能 被 网 站 的 其 他 用 户 访问 ,因此 可 以 
在 不 同 的 页 面 间 共 享 数据 ,但 是 不 能 在 用 户 间 共享 数据 。 


4.5.1 Session 对 象 的 属性 

每 个 浏览 器 有 各 自 的 Session 对 象 , 用 于 保存 浏览 器 独 享 的 信息 。 当 浏览 器 连 人 一 个 
Web 服务 器 时 ,服务 器 就 会 为 它 创建 一 个 Session 对 象 , 只 要 用 户 不 关闭 浏览 器 或 会 话 不 过 
期 ,此 Session 对 象 就 会 始终 存在 。 
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Session 的 含义 为 会话, 用 户 从 打开 某 个 网 页 开始 到 关闭 该 网 页 为 止 的 整个 过 程 就 称 
为 会 话 。 
下 面 介绍 Session 对 象 的 常用 属性 。 

1. SessionlD 属性 

当 浏览 器 首次 与 服务 器 建立 连接 时 ,服务 器 就 会 为 其 建立 一 个 Session 对 象 , 同 时 自动 分 
配 一 个 SessionID, 用 以 标识 浏览 器 的 唯一 身份 。SessionID 是 长 整 型 数 。 在 客户 机 上 打开 多 个 
浏览 器 ,这 些 浏览 器 分 别 访问 服务 器 的 网 页 ,服务 器 会 分 别 为 它们 创建 Session 对 象 。 

在 客户 端 ,浏览 器 会 将 本 次 会 话 的 SessionID 值 存 人 本 地 的 Cookie 中 , 当 再 次 向 服务 
器 提出 页 面 请 求 时 ,该 SessionID 值 将 作为 Cookie 信息 传送 给 服务 器 ,这 时 服务 器 就 可 以 
根据 该 值 找到 此 次 会 话 以 前 在 服务 器 上 存储 的 信息 ,如 图 4-8 所 示 。 

服务 器 为 A 创 建 一 个 


客户 机 A 的 Cookie 对 象 xs Session 对 象 
响应 
Session.SessionID 
请 求 


4-8 Session 与 Cookie 的 关系 


2. Timeout 属性 

Timeout 属性 规定 了 Session 对 象 的 超时 期 限 ,以 分 钟 为 单位 ,默认 值 为 20 分 钟 。 

如 果 停 留 在 每 个 网 页 的 时 间 超 过 20 分 钟 , 则 浏览 器 对 应 的 Session 对 象 会 自动 消失 ， 
此 时 车 再 访问 新 的 网 页 , 则 服务 器 将 为 浏览 器 创建 一 个 新 的 Session 对 象 。 如 果 停 留 在 每 
个 网 页 的 时 间 均 不 超过 20 分 钟 , 则 浏览 器 对 应 的 Session 对 象 会 一 直 存在 。 

当然 可 以 修改 Session 对 象 的 超时 期 限 ,如 将 超时 期 限 修改 为 30 分 钟 ,语句 如 下 : 


Session.Timeout= 30; 


3. Contents 属性 

Contents 是 一 个 集合 , 包含 一 系列 的 变量 ,方法 ,表示 其 变量 、 方 法 时 可 以 省 略 
Contents 集合 名 。 

(1) Session. Contents 集合 的 变量 

(D 定义 Contents 集合 的 变量 : 


Session.Contents[" 变 量 名 "]= 值 


Session[" 变 量 名 "]= 值 


加 Session. Contents 集合 的 变量 用 于 保留 一 些 独 享 信息 。 

@ Session[ "变量 名 "] 的 类 型 为 Object, 若 不 存在 指定 的 变量 名 , 则 Session[ "变量 名 "] 
返回 null。 

(2) Session. Contents 集合 的 方法 

(D Session. Remove(" 7E fg 4") : 移 除 Session. Contents 集合 中 指定 名 称 的 变量 。 


第 4 章 ASP.NET 内 置 对 象 


@ Session. RemoveAll() : 移 除 Session. Contents 集合 中 的 全 部 变量 。 
【 例 4-9】 在 站 点 中 添加 名 称 分 别 为 timeoutl. aspx 和 timeout2. aspx 的 两 个 网 页 。 首 
先 运行 timeoutl. aspx 网 页 ,向 Session. Contents 中 添加 信息 ,运行 界面 如 图 4-9 所 示 , 单 击 
超 链接 时 就 能 运行 timeout2. aspx 网 页 ,显示 Session. Contents 中 的 信息 。 
可 无 标题 页 - Hicroso ft Internet Explorer 


i Xét) SEO FEV KEW IAW 9800 
E Hi W) [E http: //Localhost:4734/chap04/Session/tineout1. aspx 国 


浏览 器 对 应 的 SessionID 为 ，ejxve4bwz4rchljuvhqbry3y 


进入 timeout2 aspx 


4-9 timeoutl. aspx 的 运行 界面 


(1) timeoutl. aspx. cs 的 程序 代码 如 下 : 


protected void Page Load (object sender, EventArgs e) 
| 

Session.Timeout-1; 

Session["no"]-1; 

Session ["name"]- "SK — "; 

Response.Write(" 浏 览 器 对 应 的 SessionID Jy : " *- Session.SessionID); 
) 


(2) timeout2. aspx. cs 的 程序 代码 如 下 : 


protected void Page Load(object sender, EventArgs e) 

{ 
Response.Write ("学 号 :"+ Session["no"]* "<br> ") ; 
Response.Write ("lf & :"+ Session["name"] "<br> "); 
Response.Write(" 浏 览 器 对 应 的 SessionID Jj : "+ Session.SessionID); 

) 


程序 说 明 : 如 果 停 留 在 timeoutl. aspx 的 时 间 超 过 1 分 钟 , 则 不 能 显示 Session. 
Contents 中 的 信息 。 


4.5.2 Session 和 Cookie 的 区 别 


Session 和 Cookie 非常 相似 ,都 可 以 用 来 存储 不 同 用 户 的 私有 信息 ,并 且 都 有 时 效 性 。 
但 是 ,两 者 之 间 又 有 一 定 的 区 别 。 

(1) Session 是 处 于 会 话 状态 ,只 有 特定 会 话 中 的 用 户 可 以 访问 该 信息 ,其 信息 存放 在 
服务 器 上 。 而 Cookie 处 于 客户 端 状态 管理 ,其 信息 存放 在 客户 端的 浏览 器 上 。 

(2) Session 在 服务 器 端 存 储 , 安 全 性 较 好 ,但 会 占用 系统 资源 。 而 Cookie 保存 在 客户 
端 ,安全 性 较 差 , 有 被 自 改 或 欺骗 的 可 能 ,可 通过 算法 加 密 来 弥补 。 因 此 ,建议 将 登录 信息 等 
重要 信息 存放 在 Session 中 ,其 他 不 影响 网 站 安全 性 的 信息 可 以 存放 在 Cookie 中 。 

(3) Session 存储 的 数据 量 是 不 受 限制 的 ,而 Cookie 存储 的 数据 量 很 受 限制 ,大 多 数 浏 
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览 器 支持 的 最 大 容量 为 4KB, 因 此 不 要 用 来 保存 数据 集 及 其 他 数据 量 较 大 的 信息 。 

(4) Cookie 用 来 存储 用 户 连续 访问 一 个 页 面 时 所 使 用 的 信息 ,而 Session 信息 可 以 在 
该 网 站 的 任意 一 个 页 面 ,任意 时 间 被 访问 。 

(5) 实际 上 客户 的 Session 信息 是 通过 HTTP 头 信息 中 名 为 ASPSESSIONID 的 
Cookie 在 客户 端 和 服务 器 端 进行 传送 的 。 因 此 ,如 果 客 户 端 完 全 禁用 了 Cookie 功能 , 则 
Session 就 会 失效 。 


4.5.3 Session 对 象 的 应 用 


利用 Session 对 象 可 以 实现 密码 验证 、 购 物 车 功能 等 。 

【 例 4-10]. 利用 Session 对 象 实现 密码 验证 。 

CD 在 站 点 中 添加 一 个 名 称 为 mm. aspx 的 网 页 ， 
初始 界面 如 图 4-10 所 示 。 

(2) 在 mm. aspx. cs 文件 中 编写 代码 ， 


图 4-10 例 4-10 初始 界面 


protected void Page Ioad(abject sender, EventArgs e) 
( 
if(!Page.IsPostBack) 
{ 
Session["name"]= "chen"; 
Session["password"]- "123"; 
) 
else 
{ 
if (TextBoxl.Text-- Session["name"].ToString() && 
TextBox2.Text-- Session ["password"].ToString()) 
Response.Write ("你 是 一 位 合法 用 户 "); 
else Response.Write ("你 是 非法 用 户 "); 


) 


(3) 运行 页 面 , 若 输入 的 用 户 名 、 密 码 为 chen 和 123, 则 显示 “你 是 一 位 合法 用 户 ”, 否 则 
显示 “你 是 非法 用 户 ”。 

【 例 4-11] 利用 Session 对 象 创建 购物 车 。 

CD 在 站 点 中 添加 一 个 名 称 为 gwcl. aspx 的 网 页 ,该 页 面 的 HTML 代码 如 下 : 


< form id- "forml" runat="server"> 
«div style= "text- align: center"> 
肉 铺 :<br/><hr/> 
«asp:CheckBox ID- "C1" runat- "server" Text- "猪肉 "/> 
«asp:CheckBox ID- "C2" runat="server" Text- "牛肉 "/> 
«asp:CheckBox ID- "C3" runat="server" Text- "f [4] "/» 
<br/><br/> 
«asp:Button ID- "Button?" runat="server" Text- "提交" OnClick- "Button2 Click"/> 
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«asp:Button ID-"Buttonl" runat="server" Text=" 查 看 " PostBackUrl="~ /Session/gwc2. 
aspx"/» 

«/div» 

</form> 


(2) gwcl. aspx. cs 文件 的 程序 代码 如 下 : 


protected void Button2 Click(object sender, EventArgs e) 
t 

if (Cl.Checked) Session["s1"]-Cl.Text; 

if (C2.Checked) Session["s2"]- C2.Text; 

if (C3.Checked) Session["s3"]- C3.Text; 
) 


(3) 在 站 点 中 添加 一 个 名 称 为 gwc2. aspx 的 网 页 ,该 页 面 的 HTML 代码 如 下 : 


« form id- "forml" runat="server"> 

<asp:Label ID- "labell" runat="server" Text- "你 选择 的 结果 是 : "/» «br» 
<asp:Label ID- "label2" runat- "server"/» «br» 

<asp:Label ID- "label3" runat- "server"/» «br» 

«asp:Label ID- "label4" runat- "server"/» «br» 

<“/form> 


(4) gwe2. aspx. es 文件 的 程序 代码 如 下 : 


protected void Page Load(object sender, EventArgs e) 
{ 

label2.Text= Session["s1"]+""; 

label3.Text- Session["s2"]+""; 

label4.Text- Session["s3"]+""; 
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在 开发 ASP. NET 应 用 程序 时 ,需要 对 服务 器 进行 必要 的 设置 ,如 服务 器 编码 方式 等 ; 
或 获取 服务 器 的 某 些 信息 ,如 服务 器 的 名 称 、 页 面 超时 时 间 等 ,这 些 都 可 以 通过 Server 对 象 


4.6.1 Server 对 象 的 属性 
Server 对 象 的 常用 属性 见 表 4-7。 
表 4-7 Server 对 象 的 常用 属性 
属 人 性 说 明 
MachineName 获取 服务 器 的 计算 机 名 称 


设置 脚本 在 n 秒 内 执行 ,车 超出 就 显示 出 错 信息 。 可 以 通过 IIS 设置 
脚本 超时 ,默认 为 90 秒 


ScriptTimeout 


102. ASP. NET 网 站 开发 案例 教程 
p 


例如 , 若 想 将 脚本 超时 期 限 设置 为 100 秒 , 可 使 用 如 下 语句 : 


Server.ScriptTimeout- 100; 


4.6.2 Server 对 象 的 方法 


Server 对 象 的 常用 方法 见 表 4-8 所 示 。 
表 4-8 Server 对 象 的 常用 方法 
方 法 说 明 


Execute X fF") 执行 指定 的 新 网 页 , 当 新 网 页 执行 完毕 后 ,继续 原 网 页 的 执行 


执行 指定 的 新 网 页 ,并 将 原 网 页 的 所 有 内 置 对 象 的 值 保留 到 新 网 页 中 ,但 不 


Transfer( 文件 名 ") 。 | 返回 原 网 页 。 如 执行 到 新 网 页 时 ,IE 的 地 址 栏 仍 显示 原 网 页 的 URL 


对 含有 HTML 标记 的 字符 串 编码 ( 即 *“<<” 变 成 “ &lti " "7 "HER Bgm 


HtmlEncode( 字 符 串 ) 使 下 能 显示 标记 本 身 


HtmlDecode( 字 符 串 ) | 对 经 过 编码 的 字符 串 进 行 解码 


MapPath(" 文 件 名 ") 将 指定 文件 (或 文件 夹 ) 映 射 到 当前 页 面 所 在 目录 之 下 ,返回 指定 文件 (或 文 
MapPath( "文件 夹 ") 件 夹 ) 的 绝对 路 径 


对 MapPath 方法 ,再 说 明 如 下 : 


MapPath (" ../ 文 件 名 ") 
MapPath (" ../ 文 件 夹 ") 


功能 : 将 指定 文件 (或 文件 夹 ) 映 射 到 当前 页 面 所 在 目录 的 上 一 级 目录 之 下 。 
【 例 4-12] Server 对 象 的 Execute 方法 使 用 示例 。 
COD. 在 站 点 中 添加 一 个 名 称 为 Execute. aspx 的 网 页 ,. cs 文件 的 程序 代码 如 下 : 


protected void Page Load(object sender, EventArgs e) 
t 
Server.ScriptTimeout- 100; 
Response.Write ("< p> WJH Execute 方法 之 前 </p>"); 
Server.Execute ("Page2 .aspx") ; // 执 行 Page2.aspx 后 会 再 返回 
Response.Write ("<p> WJH Execute 方 法 之 后 </p>"); 
} 


(2) 在 站 点 中 添加 一 个 名 称 为 Page2. aspx 的 网 页 ,. cs 文件 的 程序 代码 如 下 : 


protected void Page Load(object sender, EventArgs e) 
1 
Response.Write ("<P> 这 是 Page2.aspx 的 执行 结果 < /P>"); 
} 
运行 Execute. aspx 页 面 ,运行 结果 如 图 4-11 所 示 。 
【 例 4-13] Server 对 象 的 Transfer 方法 使 用 示例 。 
在 站 点 中 添加 一 个 名 称 为 Transfer. aspx 的 网 页 ,. cs 文件 的 程序 代码 如 下 : 


protected void Page Load(object sender, EventArgs e) 


于 无 标题 页 - 了 icrosoft Internet Explorer 


| xo BEO SEV KAW IAD Wb 


ERBEQD [i] http://1ocslhost/chap04/Server/Execute. sse MERS 


调用 Execute 方 法 之 前 
这 是 Page2.aspx 的 执行 结果 
调用 Execute 方法 之 后 


图 4-11 Execute. aspx 的 运行 结果 


Response.Write("<p> 调 用 Transfer 方 法 之 前 < /p» ") ; 

Server.Transfer ("Page2.aspx") ; 

Response.Write ("<p> Ñ Hl Transfer 方 法 之 后 < /p» ") ; 
} 
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// 将 控制 权 转移 至 Page2.aspx 后 便 不 再 返回 


运行 Transfer. aspx 页 面 ,运行 结果 如 图 4-12 所 示 , TE. 的 地 址 栏 中 仍 显示 原 网 页 


的 URL. 


J 无 标题 页 - Nicrosoft Internet Explorer [3] 


| 文件 四 ep SEO KEW IAV Who 


É EBHE D) [d] http://1ocalhost/chap04/Server/Transfer. aspx [| EJ HSI 


调用 Transfer 方 法 之 前 
这 是 Page2.aspx 的 执行 结果 


4-12. Transfer. aspx 的 运行 结果 


【 例 4-14] Server 对 象 的 HtmlEncode 方法 使 用 示例 。 
程序 代码 如 下 : 


protected void Page Load(object sender, EventArgs e) 
{ 
Response.Write (Server.HtmlEncode ("<b> illl 3; < /b» ") ) ; 


47 项 目 实 训 


实 训 1 MRE 


实 训 目 的 

(1) 掌握 Web 控件 的 使 用 方法 。 

(2) 掌握 Application 对 象 的 属性 和 应 用 。 
实 训 要 求 

(1) 创建 一 个 Web 网 站 sx04 ,并 设置 成 虚拟 目录 。 


(2) 在 网 站 中 添加 一 个 名 称 为 sx4_1. aspx 的 网 页 , 当 用 户 在 文本 框 中 输入 一 段 文 


qr 
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单 击 “提交 ”按钮 时 ,这 些 文字 就 会 显示 在 下 方 标签 中 ; 当 用 户 单 击 “ 清 空 ”按钮 时 ,会 将 
Appliction 对 象 和 标签 清空 ,如 图 4-13 所 示 。 


2.828. - Kicrosoft Internet Ex... [- | X] 
ix em SEV KEW IA” AY 
;地 让 加 [Æ] http://localhost: 1119/chsp04/sx M| EJ 530 


aaaaaaaaa 
bbbbbbbbbbbb 


图 4-13 简易 聊天 室 


实 训 2 会 话 超时 
实 训 目 的 


(D) 掌握 Session 对 象 的 Timeout 属性 。 
(2) 掌握 Session 对 象 的 Contents 集合 。 


实 训 要 求 
在 网 站 中 添加 一 个 名 称 为 sx4_2. aspx 的 网 页 , 当 装 载 页 面 时 ,能 将 用 户 的 学 号 、 姓 名 存 
入 Session 对 象 中 ,并 显示 系统 的 当前 时 间 和 Session 对 象 的 内 容 ,规定 Session 对 象 的 超时 
期 限 为 1 分钟。 超过 1 分 钟 后 , 单 击 “ 演 示 ” 按 钮 时 ,页 面 失 效 。 运 行 结 果 如 图 4-14 所 示 。 
加 第 ! 题 - 了 icrosoft Internet Explorer 


i Xf bp FEV KEW IAW 帮助 如 
é BEW |] http: /localhest:11191chap04/ sx04/sx4_2.aspx 


当前 时 间 231012 
第 1 个 Session 的 值 1 
第 2 个 Session 的 值 张 三 


图 4-14 会 话 超时 


实 训 3 Request 的 应 用 


实 训 目的 
(D 熟悉 各 类 验证 控件 的 应 用 。 
(2) 掌握 Request 对象 的 应 用 。 


实 训 要 求 

CD 在 网 站 中 添加 名 称 分 别 为 sx4_3. aspx 和 2b. aspx 的 两 个 网 页 。 

(2) sx4 3. aspx 网 页 的 初始 界面 如 图 4-15 所 示 ,其 中 年 龄 的 第 2 个 验证 控件 要 求 是 比 
较 验 证 。 
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(3) 如 果 各 项 填写 正确 , 则 单 击 “提交 ”按钮 后 ,就 会 在 2b. aspx 页 面 中 显示 出 相应 的 信 


息 ,运行 结果 如 图 4-16 所 示 。 


学 8 [p 
姓名 E 


2010001 


MA [03 ORTE 


张 三 


Fit 


系 别 REER a 


图 4-15 Request 对 象 的 应 用 


实 训 4 网 上 投票 


实 训 目的 
(1) 掌握 Application 对 象 的 使 用 方法 。 
(2) 掌握 Session 对 象 的 使 用 方法 。 


4-16 2b. aspx 运行 界面 


(3) 掌握 Application 对 象 Session 对 象 之 间 的 区 别 。 


(4) 了 解 Global. asax 文件 的 应 用 。 


实 训 要 求 

CD 在 网 站 中 添加 一 个 名 称 为 sx4_4. aspx 的 网 
页 ,用 于 实现 网 上 投票 以 及 结果 统计 。 

(2) sx4_4. aspx 页 面 的 设计 视图 如 图 4-17 所 示 。 
上 方 表格 用 于 统计 投票 结果 ,下 方 表格 包含 1 个 
RadioButtonList 控件 、1 个 Button 控件 和 1 Label 
控件 ,用 于 用 户 的 网 上 投票 。 

(3) 在 Global. asax 文件 中 设置 4 个 Application 
变量 ,分 别 统计 4 个 NBA 篮球 队 的 总 票数 ,设置 1 个 
Session 变量 ,用 来 标志 当前 用 户 的 投票 次 数 。 

OD 用 户 每 打开 一 次 IE 并 访问 sx4_4. aspx 页 面 ， 
允许 投 一 次 票 ,系统 会 实时 统计 各 篮球 队 的 得 票 总 数 
并 显示 到 表格 中 , 若 投票 次 数 超过 1 次 , 则 在 Label 控 
件 中 显示 “对 不 起 ! 您 已 经 投 过 票 了 !”。 

实 训 提示 

(D) Global. asax 主要 程序 代码 : 


void Application Start (object sender, EventArgs e) 


票 统计 
姓名 EK 
太阳 Eabel 
火箭 Eabel 
马刺 Ebel 
热 Eabel 
您 认为 谁 是 今年 NBA 的 总 冠军 ? 请 选择 ， 
foxa 
OX 
ozi ELE 
o 


4-17. sx4 4. aspx 的 设计 视图 


{ Application["nl"]-0; // 初 始 化 候选 人 的 总 票数 


Application["n2"]-0; 
Application["n3"]- 0; 
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Application["n4"]-0; 
) 
void Session Start (object sender, EventArgs e) 
( Session["n"]-0; 


) 
(2) sx4 4. aspx. cs 文件 的 主要 代码 : 


protected void Page Load(object sender, EventArgs e) 

t 
Labell.Text-Convert.ToString (Application ["n1"]) ; 
Label2.Text- Convert .ToString (Application ["n2"]) ; 
Label3.Text-Convert.ToString (Application["n3"]) ; 
Label4.Text-Convert.ToString (Application["n4"]) ; 


protected void Buttonl Click(object sender, EventArgs e) 


{ 


Session["n"]= (int)Session["n"]+1; 


if ((ünt)Session["n"]« 2) 


{ 


Application.Lock(); 
Switch (RadioButtonListl.SelectedIndex) 


{ 


case 0: Application["n1"]- Convert.ToInt32 (Application["n1" 


Llabell.Text-Convert.ToString (Application["nl" 
break; 


E 


case 1: Application["n2"]- Convert.ToInt32 (Application["n2" 


Llabel2.Text-Convert.ToString (Application["n2" 
break; 


E 


case 2: Application["n3"]- Convert.ToInt32 (Application["n3" 


Llabel3.Text-Convert.ToString (Application["n3" 
break; 


case 3: Application["n4"]- Convert .ToInt32 (Application[" 


label4.Text-Convert.ToString (Application["n4" 
break; 


Application.UnLock (); 


} 


else Label5.Text- "对不起! 您 已 经 投 过 票 了 1"; 


); 


"n4" 


) 7 


// 初 始 化 用 户 提交 投票 的 次 数 


)+17 


)+17 


)+17 


)+1; 
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思考 与 练习 

一 、 填 空 题 

1. Application 对 象 用 于 保存 信息 ,Application 对 象 的 生存 期 是 è 

2. Session 对 象 用 于 保存 信息 ,Session 对 象 的 生存 期 是 5 

3; 是 第 一 次 加 载 网 页 时 才 会 触发 的 事件 ; 是 每 次 加 载 网 页 时 都 会 触 
发 的 事件 。 

A. 表单 数据 返回 服务 器 端的 方式 有 和 两 种 ,默认 为 EE 

5. Session 对 象 的 有 效 时 间 默 认 值 为 分 钟 ,Server 对 象 的 ScriptTimeout 属性 
默认 脚本 超时 期 限 为 秒 。 

二 、 简 答题 


1. Response, Request 和 Server 对 象 各 有 什么 作用 ? 

2. 对 于 Web 控件 ,Request [ "控件 标识 "] 与 “控件 标识 . Text* 有 什么 区 别 和 联系 ? 
3. 简 述 Application 对 象 和 Session 对 象 之 间 的 区 别 。 

A. 如 何 使 用 Server 对 象 获取 服务 器 的 信息 ? 


gos 
— "ASP.NET 数据 库 编程 


数据 库 技术 是 使 用 计算 机 进行 数据 管理 的 核心 技术 ,几乎 所 有 的 管理 信息 系统 都 是 以 
数据 库 为 基础 的 。 使 用 ASP. NET 进行 应 用 程序 开发 时 ,也 一 定 离 不 开 数据 库 技术 。 


BIRA 


。 掌握 ADO. NET 的 组 件 结构 

。 掌握 使 用 Connection 对 象 连接 数据 库 的 方法 

。 掌握 如 何 使 用 Command 对 象 运行 SQL 语句 

。 掌握 如 何 使 用 DataReader 对 象 读 取 数 据 库 

。 掌握 如 何 使 用 DataAdapter 和 DataSet 对 象 读 取 和 操纵 数据 库 


5.1 ADO. NET 简介 


在 ASP. NET 应 用 程序 中 访问 数据 库 要 通过 ADO. NET(Active Data Object, ADO) Æ 
实现 , 即 ADO. NET 是 Web 应 用 程序 与 数据 库 之 间 的 接口 。 

ADO. NET 包含 两 大 核心 模块 : .NET Framework 数据 提供 程序 和 DataSet 数据 集 。 

. NET Framework 数据 提供 程序 用 于 连接 数据 库 .执行 命令 和 检索 结果 ,. NET Framework 
提供 了 以 下 4 种 数据 提供 程序 。 

(1) SQL Server .NET Framework 数据 提供 程序 : 适用 于 Microsoft SQL Server 7. 0 
或 更 高 的 版 本 , 它 位 于 System. Data. SqlClient 命名 空间 中 。 

(2) OLEDB .NET Framework 数据 提供 程序 : 适用 于 所 有 提供 了 OLEDB 接口 的 数 
据 源 ,包括 Access, Excel, SQL Server 6. 5 或 更 低 版 本 的 数据 库 等 , 它 位 于 System. Data. 
OleDb 命名 空间 中 。 

(3) ODBC .NET Framework 数据 提供 程序 : 适用 于 所 有 提供 了 ODBC 接口 的 数据 
源 , 它 位 于 System. Data. Odbc 命名 空间 中 。 

(4) Oracle .NET Framework 数据 提供 程序 : 适用 于 Oracle 数据 源 , 它 位 于 System. 
Data. OracleClient 命名 空间 中 。 

.NET Framework 数据 提供 程序 提供 了 4 个 核心 对 象 。Connection 对 象 用 于 创建 当 
前 页 面 与 数据 库 的 连接 。Command 对 象 用 于 执行 命令 文本 (包括 SQL 语句 、 表 名 ,存储 过 
TEE). DataReader 对 象 代表 一 个 记录 集 , 用 户 只 能 从 中 读 取 数据 ,不 能 写 人 数据 。 
DataAdapter 对 象 是 连接 DataSet 对 象 和 数据 库 的 桥梁 ,负责 将 数据 库 中 的 数据 取出 后 填充 


到 DataSet 对 象 中 ,或 者 将 数据 存 回 数据 库 中 。 


SQL Server .NET Framework 数据 提供 程序 提供 的 4 个 
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ASP.NET 页 面 


核心 对 象 为 SqlConnection、SqlCommand、SqlDataReader、 | DataReader 


SqlDataAdapter。OLEDB . NET Framework 数据 提供 程序 提 
供 的 4 个 核心 对 象 为 OleDbConnection、OleDbCommand、 


OleDbDataReader .OleDbDataAdapter。 


DataSet 是 一 个 功能 丰富 、 较 复杂 的 数据 集 , 它 专门 用 
来 处 理 从 数据 源 获得 的 数据 。DataSet 对 象 是 ADO. NET 
的 核心 ,代表 内 存 中 的 一 个 数据 库 , 它 可 以 存储 多 个 表 以 及 


各 表 间 的 关系 。ADO. NET 的 对 象 模型 如 图 5-1 所 示 。 
由 于 本 章 及 后 续 章 节 要 用 到 SQL Server 数据 库 stu. 
为 了 后 面 应 用 方便 ,这 里 将 stu 的 各 个 表 的 结构 和 记录 分 别 列 出 。 


(1) student 的 结构 和 记录 ( 见 表 5-1) 


X 5-1. student X 


DataSet 


DataA dapter 


Command 


Connection 


数据 库 


图 5-1 ADO. NET 的 对 象 模型 


列 名 数据 类 型 大 小 是 否 人 允许 空 列 名 含义 
sno char 5 N 学 号 
2 sname char 6 姓名 
3 ssex char 2 性 别 
4 sage int 年 龄 
5 sdept char 10 系 别 
Ds EL * EN Eam 
mo S E n a 
95004 张 立 5 Is 
(2) course 的 结构 和 记录 ( 见 表 5-2) 
表 5-2 course X 
列 名 数据 类 型 大 小 是 否 允 许 空 列 名 含义 
à cno char 10 N 课程 编号 
2 cname char 20 课程 名 称 
3 credit int 课程 学 分 


cno cname credit. 
>T 数据 库 系统 原理 4 

2 Javs 程 序 设计 3 

3 操作 系统 3 

4 汇编 语言 3 

5 多 媒体 技术 。 “2 

e JSP 网 络 编程 4 
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(3) sc 的 结构 和 记录 ( 见 表 5-3) 


表 5-3 sc 表 
列 名 数据 类 型 大 小 是 否 允 许 空 列 名 含义 
1 sno char 5 N 学 号 
2 cno char 2 N 课程 编号 
3 grade int 成 绩 


5.2. 使 用 Comection 对 象 连接 数据 库 


在 对 数据 库 中 的 数据 进行 操作 之 前 要 先 连 接 数 据 库 , 本 节 将 通过 实例 介绍 如 何 连接 
Microsoft SQL Server 数据 库 和 Microsoft Access 数据 库 。 这 两 个 数据 库 比 较 有 代表 性 ,其 他 数 
据 库 的 连接 可 以 参考 这 两 个 数据 库 的 连接 方法 。 连 接 数据 库 并 完成 了 对 数据 库 的 操作 之 后 ， 
必须 关闭 与 数据 库 的 连接 ,可 以 使 用 Connection 对 象 的 Close 或 Dispose 方法 来 完成 。 


5.2.1 Connection 对 象 简介 
1. 创建 Connection H% 


SqlConnection 对 象 名 =new SqlConnection [连接 字符 串 ]); 
OleDbConnection 对 象 名 =new OleDbConnection ([ 连 接 字符 串 ]); 


SqlConnection 对 象 和 OleDbConnection 对 象 的 区 别 仅 在 于 适用 的 数据 源 不 同 ,其 属性 
和 方法 完全 相同 ,因此 把 它们 统称 为 Connection 对 象 , 即 连接 对 象 。 

格式 中 的 “[ 连 接 字 符 串 ]? 用 于 指定 连接 方式 , 它 随 着 连接 的 数据 源 的 不 同 而 不 同 。 若 
该 参数 省 略 , 则 可 在 创建 Connection 对 象 之 后 再 指定 其 属性 。 

2. Connection 对 象 的 属性 和 方法 

Connection 对 象 的 属性 和 方法 如 表 5-4 所 示 。 


X 5-4 Connection 对 象 的 属性 和 方法 


属性 和 方法 说 — 9 
ConnectionString 设置 或 取得 连接 字符 串 
OpenO 打开 数据 库 的 连接 
Close 关闭 数据 库 的 连接 
Dispose() 关闭 数据 库 连 接 ,并 释放 所 占用 的 系统 资源 
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例如 : 


String str- "Data Source- localhost; Initial Catalog-Northwind; Integrated Security- True"; 
SqlConnection con-new SglConnection (str); 


可 写成 


SglConnection con=new SqlConnection (); 
con.ConnectionString= "Data Source= localhost; Initial Catalog-Northwind; Integrated Security 


-True"; 


5.2.2. 连接 SQL Server 数据 库 
连接 数据 库 的 方式 有 两 种 : 图 形 方 式 和 字符 方式 。 


1. 用 图 形 方式 连接 SOL Server 数据 库 

【 例 5-1) 用 图 形 方式 连接 SQL Server 2000 中 的 Northwind 数据 库 ,如 果 连 接 成 功 ， 
则 输出 连接 成 功 的 信息 ;如 果 连 接 失 败 , 则 输出 连接 错误 的 信息 。 

操作 步骤 如 下 : 


(1) 在 网 站 中 添加 一 个 名 称 为 SQLCon. aspx A 


的 网 页 ,在 Web 网 页 中 添加 一 个 SqlDataSource | sea: 
控 件 i ft SQL Server (SqlClient) mO] 


(2) 在 “属性 ”窗口 中 选择 ConnectionString | 0 mw) 
属性 ,打开 右 侧 的 下 拉 列 表 , 选 择 “ 新 建 连接 ” 命 
令 , 打 开 如 图 5-2 所 示 的 “添加 连接 "对话 框 。 

(3) 单 击 “ 更 改 ” 按 钮 ,在 打开 的 “更 改 数据 
源 ” 对 话 框 中 选择 Microsoft SQL Server 选项 。 

(4) 设置 要 连接 的 服务 器 名 ,然后 选择 登录 
SQL Server 数据 库 的 方式 ,如果 选 择 了 “使 用 
SQL Server 身份 验证 ”方式 , 则 还 需要 指定 登录 
名 和 密码 ,最 后 选择 默认 打开 的 数据 库 。 

(5) 单 击 “ 测 试 连接 ”按钮 ,如 果 显示 如 图 5-3 
所 示 的 对 话 框 , 则 表示 连接 成 功 。 

(6) 单 击 “确定 "按钮, 将 完成 数据 库 的 连接 ， Mor pud 
此 时 “属性 ”窗口 中 的 ConnectionString ff f& 2E 
为 : Data Source 王 Al; Initial Catalog= Northwind; Integrated Security= True, 


(7) 在 Web 网 页 中 添加 其 他 控件 ,使 初始 界面 如 图 5-4 所 示 。 


连接 测试 例子 


Hicrosoft Visual Studio [X] 


人 ps 


conn str 
tomm oper] 
tom close] 


"SalDateSource - Sqllatasooreel 
5-3 “测试 连接 成 功 ?对 话 框 图 5-4 SQLCon. aspx 的 初始 界面 
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(D 编写 程序 代码 。 


在 声明 命名 空间 区 域 添 加 : 

using System.Data.SqlClient; 

主要 代码 如 下 : 

1. protected void Page Load(object sender, EventArgs e) 
2 

3 String str- SqlDataSourcel.ConnectionString; 
4 conn str.Text- str; 

5 SglConnection con- new SqlConnection (str); 
6. try 

7 t 

8 con.Open() ; 

9 conn open.Text- "连接 成 功 !"7 

10. con.Close(); 

1. conn close.Text- "EET X: BI] 1"; 

12. ) 

13. catch (Exception) 

14. { 

15. ”conn_open.Text=" 连 接 失 败 !"; 

16. } 

11.3} 


2. 用 字符 方式 连接 SOL Server 数据 库 

【 例 5-2】 用 字符 方式 连接 SQL Server 2000 中 的 Northwind 数据 库 , 如 果 连 接 成 功 ， 
则 输出 成 功 的 信息 ;如 果 连 接 失 败 , 则 输出 连接 错误 的 信息 。 

操作 步骤 如 下 : 

CD 删除 图 5-4 中 的 SqlDataSourcel 控件 。 

(2) 将 例 5-1 的 程序 代码 中 的 第 3 行 改 为 : 


String str= "Data Source= localhost;Initial Catalog-Northwind; Integrated Security- True"; 
或 者 
String str-"server- localhost;uid- sa;pwd- ;database- Northwind;Trusted Connection- no"; 


前 者 为 信任 连接 ,即使 用 Windows 登录 名 连接 到 SQL Server 2000 ,无 须 提供 登录 名 和 
密码 ,格式 为 : 

String str= "Data Source= 服 务 器 名 ;Initial Catalog= 数 据 库 名 ;Integrated Security=True"; 

后 者 为 非 信任 连接 ,即使 用 SQL Server 登录 名 连接 到 SQL Server 2000 ,必须 提供 登录 
名 和 密码 ,格式 为 : 


String str="server= 服 务 器 名 ;uid= sql server 登录 名 ;pwd= 密 码 ;database= 数 据 库 名 ;Trusted_ 
Connection-no "; 
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5.2.3 连接 Access 数据 库 


1. 用 图 形 方式 连接 Access 数据 库 

【 例 5-3] 用 图 形 方式 连接 站 点 根 目录 下 App_Data\ Northwind. mdb 数据 库 , 如 果 连 
接 成 功 , 则 输出 连接 成 功 的 信息 ;如 果 连 接 失 败 , 则 输出 连接 错误 的 信息 。 

操作 步骤 如 下 : 

(1) 在 网 站 中 添加 一 个 名 称 为 AccessCon. aspx 的 网 页 ,在 Web 网 页 中 添加 
SqlDataSource 控件 后 ,在 “属性 ”窗口 中 选择 ConnectionString 属性 ,再 新 建 一 个 连接 ,打开 
如 图 5-2 所 示 的 “添加 连接 ”对 话 框 。 单 击 “ 更 改 ” 按 钮 ,在 打开 的 “更 改 数 据 源 ”对 话 框 中 选 
ff" Microsoft Access 数据 库 文件 ?选项 。 单 击 * 浏 览 ?按钮 ,选择 数据 库 文 件 Northwind. 
mdb, 单 击 “ 测 试 连接 ”按钮 ,弹出 “测试 连接 成 功 ” 信 息 , 表 明 数 据 库 连 接 成 功 。 单 击 “ 确 定 ” 
按钮 ,关闭 “添加 连接 ”对 话 框 ,此 时 ,查看 ConnectionString 属性 ,其 值 如 下 : 

Provider-Microsoft.Jet.OLEDB.4.0;Data Source=E:\ 清 华 大 学 出 版 社 \ 案 例 \chap05\App_Data\ 

Northwind.mdb 

(2) 在 Web 网 页 添加 其 他 控件 ,使 初始 界面 如 图 5-4 所 示 。 

(3) 编写 程序 代码 。 


在 声明 命名 空间 区 域 添加 : 

using System.Data.OleDb; 

主要 代码 如 下 : 

1. protected void Page Load(object sender, EventArgs e) 
2. 

3 String str-SqlDataSourcel.ConnectionString; 

4 conn str.Text- str; 

5 OleDbConnection con-new OleDbConnection (str); 
6. try 

7 1 

8 con.Open () ; 

9 conn open.Text- "连接 成 功 ! "; 

10. con.Close(); 

It. conn close.Text- "连接 关闭 !"; 

12. i 

13. catch (Exception) 

14. { 

15. conn open.Text- "连接 失败 !"7 

16. } 

1} 


2. 用 字符 方式 连接 Access 数据 库 
【 例 5-4】 用 字符 方式 连接 站 点 根 目录 下 的 App_Data\ Northwind. mdb 数据 库 , 如 果 
连接 成 功 , 则 输出 成 功 的 信息 ;如 果 连 接 失 败 , 则 输出 连接 错误 的 信息 。 
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操作 步骤 如 下 : 
CD 删除 图 5-4 中 的 SqlDataSourcel 控件 。 
(2) 将 例 5-3 的 程序 代码 中 的 第 3 行 改 为 : 


String str="provider= Microsoft. Jet.OLEDB. 4. 0; data source="+ Server.MapPath ("App Data/ 
Northwind.mdb"); 


5.3 使 用 Command 对 象 


在 连接 数据 库 后 ,可 以 读 取 和 操作 数据 库 中 的 数据 。 下 面 介 绍 如 何 通过 SqlCommand 
和 OleDbCommand 类 来 操作 数据 库 中 的 数据 。 


1. 创建 Command 对 象 
Command 对 象 ( 即 命令 对 象 ) 的 创建 格式 如 下 : 


SqlCommand 对 象 名 =new SqlConmand (命令 文本 ,连接 对 象 ) ; 
OleDbCommand 对 象 名 =new OleDbCommand (命令 文本 ,连接 对 象 ) ; 


如 果 使 用 的 数据 库 是 SQL Server 2000, 则 命令 文本 可 以 是 SQL 语句 、 存 储 过 程 名 。 如 
果 使 用 的 数据 库 是 Access, 则 命令 文本 可 以 是 SQL 语句 、 表 名 。 


2. Command 对 象 的 属性 
Command 对 象 的 常用 属性 见 表 5-5。 


X 5-5 Command 对 象 的 常用 属性 


属 性 说 明 
CommandText 获取 或 设置 要 执行 的 SQL 语句 、 表 名 、 存 储 过 程 名 
Connection 获取 或 设置 Connection 对 象 


解释 命令 文本 代表 的 意义 (SQL 语句 、 存 储 过 程 名 、 表 名 ) 
(D 若 命令 文本 为 存储 过 程 名 , 则 必须 加 入 : 

对 象 名 . CommandType— CommandType. StoredProcedure; 
O 若 命令 文本 为 表 名 , 则 必须 加 入 : 


ente 对 象 名 . CommandType— CommandType. TableDirect; 
© 车 命令 文本 为 SQL 语句 , 则 可 以 加 入 ， 
对 象 名 . CommandType— CommandType. Text; 
但 不 是 必须 的 

例如 : 


SqlCommand cmd- new SqlConmand ("select * from student", con); 
等 价 于 


SqlCommand cmd= new SqiCommand () ; 
cmd. CommandText- "select * from student"; 


cmd. Connection- con; 
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3. Command 对 象 的 方法 

假定 Command 对 象 为 cmd, 其 方法 有 以 下 几 种 。 
(1) ExecuteNonQuery() 

格式 如 下 : 


int x-cmd. ExecuteNonQuery () ; 


功能 : 执行 cmd 指定 的 命令 文本 ,并 返回 受 影响 的 行 数 。 其 中 命令 文本 必须 是 非 表 名 ， 
非 select 语句 。 

(2) ExecuteReader() 

格式 如 下 : 


SqlDataReader rs= cmd. ExecuteReader (); 
OleDbDataReader rs= cmd. ExecuteReader (); 


功能 : 执行 cmd 指定 的 命令 文本 ,并 返回 一 个 DataReader 对 象 (记录 集 对 象 ) 。 其 中 命 

令 文 本 必须 是 表 名 select 语句 。 
(3) ExecuteScalar() 
格式 如 下 : 


Object x= cmd. ExecuteScalar () ; xf p SEV BRW 


功能 : 执行 cmd 指定 的 命令 文本 ,并 返回 记录 
集 第 一 行 第 一 列 的 值 (Object 型 )。 命 令 文本 必须 
是 表 名 select 语句 。 

[5/5-5] 在 站 点 中 添加 一 个 名 称 为 
ExecuteNonQuery. aspx 的 网 页 , 当 用 户 正确 填写 


时 无 标题 页 - Nicrosoft Intern... 


数据 并 单 击 * 插 入 ”按钮 后 ,能 向 student 表 中 添加 插入 成 功 受 影响 的 行 数 为: 1 
一 条 记录 ,并 显示 “插入 成 功 !1” 等 信息 。 运 行 界面 如 BE cid 
图 5-5 所 示 。 一 — 

主要 程序 代码 如 下 e 


protected void Buttonl Click (object sender, EventArgs e) 
t 
String no= TextBoxl.Text; 
String name- TextBox2.Text; 
String sex-RadioButtonListl.SelectedValue; 
String age- TextBox3.Text; 
String dept- TextBox4.Text; 
// 创 建 连 接 对 象 con 
String str= "server- localhost;uid- sa;pwd- ;database= stu; Trusted Connection-no"; 
SqlConnection con-new SqlConnection (str); 
con.Open() ; 
// 创 建 命令 对 象 ema 
String sql= "insert into student values ('"4 not "' , "4 name "', '"+ sexe " ',"- age", '"+dept+" 
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n 
SqlCommand cmd- new SqlCommand (sql, con); 
int n= cmd.ExecuteNonQuery () ; 
labell.Text- "插入 成 功 , 受 影响 的 行 数 为 : "+n; 


Sql-"select count(* ) from student"; 

amd- new SqlCommand (sql, con); 

n= (int)and.ExecuteScalar () ; 

label2.Text- "目前 共有 "+nt "条 记录 "; 
) 


【 例 5-6】 在 站 点 中 添加 一 个 名 称 为 ExecuteReader. aspx 的 网 页 ,要求 连接 App. DataV 
Northwind. mdb, 并 显示 Customers 表 中 第 一 条 记录 的 CustomerID、CompanyName、Address。 
首先 使 用 “using System. Data. OleDb;” 引 用 命名 空间 ,具体 实现 代码 如 下 : 


protected void Page Load(object sender, EventArgs e) 
t 
String str- "Provider-Microsoft.Jet.OLEDB.4.0;Data Source- "+ Server.MapPath ("App Data/ 
Northwind.mdb"); 
OleDbConnection con- new OleDbConnection (str) ; 
con.Open () ; 
OleDbConmmand cmd- new OleDbCommand ("Customers", con); 
cmd.ComnandType- ComnandType . TableDi rect ; 
OleDbDataReader rs- amd.ExecuteReader () ; 
while (rs.Read()) 
t 
Response.Write (rs.GetValue (0) ", "4 rs.GetValue (1)- ", 4 rs.GetValue (4)) ; 
break; 
) 
rs.Close(); 
con.Close(); 


5.4 使 用 DataReader 对 象 读 取 数 据 库 


ADO. NET 有 两 种 访问 数据 库 的 方式 ,分 别 为 DataReader 对 象 及 DataSet 对 象 。 

使 用 DataReader 对 象 可 以 从 数据 库 中 检索 只 读 、 只 进 的 记录 集 。 所 谓 “ 只 读 ”, 是 指 在 
该 记录 集 上 不 可 修改 .删除 、 增 加 记录 ;所 谓 “ 只 进 ”, 是 指 记录 集中 的 记录 指针 只 能 向 后 
移动 。 

DataReader 对 象 和 数据 库 的 类 型 联系 紧密 : SQL Server 数据 库 使 用 SglDataReader 
类 ,Access 数据 库 使 用 OleDbDataReader 类 。 

使 用 DataReader 对 象 读 取 数据 库 的 步骤 如 下 : 

(1) 创建 连接 对 象 。 

(2) 创建 命令 对 象 。 
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(3) 执行 命令 对 象 指定 的 命令 文本 ( 即 select 语句 ) ,返回 记录 集 。 
(4) 读 取 记 录 集 中 的 记录 。 


1. 创建 DataReader 对 象 


SglDataReader 对 象 名 = 


Command 对 象 .ExecuteReader (); 


OleDbDataReader X} %4 — Command 对象 .ExecuteReader (); 


例如 : 


SqlDataReader rs= cmd. ExecuteReader (); 


DataReader 对 象 , 又 称 为 记录 集 对 象 ,是 由 Command 对 象 执行 ExecuteReader () 方 法 
时 生成 的 ,不 能 直接 使 用 构造 函数 声明 ,因为 SqlDataReader、OleDbDataReader 是 抽象 类 ， 


不 能 显 式 实例 化 。 


创建 记录 集 对 象 时 ,记录 指针 指向 第 一 条 记录 之 前 。 创 建 的 记录 集 对 象 为 只 读 , 且 记录 


指针 只 能 向 后 移动 。 


2. DataReader 对 象 的 属性 和 方法 
DataReader 对 象 的 属性 和 方法 见 表 5-6。 


表 5-6 DataReader 对 象 的 属性 和 方法 


属性 和 方法 说 — 9l 
FieldCount 返回 记录 集 的 字段 个 数 
GetName(i) 返回 序号 为 i 的 字段 名 (第 1 个 字段 的 序号 为 0) 
GetValue(i) 返回 当前 记录 的 字段 值 (Object 型 ), 若 要 返回 字段 原来 的 类 型 ,可 以 使 用 
GetInt32(i) .GetString(i) ,GetDateTime(i) .GetBoolean(i) 等 
Read() 将 记录 指针 指向 下 一 条 记录 , 读 取 该 记录 ,返回 一 个 布尔 值 
CloseO 关闭 记录 集 对 象 


设 DataReader 对 象 为 rs, 则 rs[ "属性 名 "] 也 会 返回 当前 记录 的 字段 值 CObject 型 ) 。 


【 例 5-7】 在 站 点 中 添加 一 个 名 称 为 rstotable. aspx 的 网 页 ， 
当 用 户 选 择 组 合 框 中 的 一 个 数据 表 , 并 单 击 “确定 ?按钮 时 ,能 将 
数据 表 以 表格 形式 显示 出 来 。 运 行 界面 如 图 5-6 所 示 。 


主要 程序 代码 如 下 : DARRE 
student 
protected void Buttonl Click (object sender, EventArgs e) es 
{ 
// 创 建 连接 对 象 con 5-6 例 5-7 运行 界面 


String str-"server- localhost; uid- sa; pud- ; database- stu; 


Trusted Connection- no"; 
SglConnection con- new SqlConnection (str); 


con.Open() ; 


// 创 建 命令 对 象 cna 
String sgl- "select * from "+ Dl.Value; 
Sql Command cmd- new SqlCommand (sql, con); 
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// 执 行 nd 指定 的 命令 文本 ,返回 记录 集 
SqlDataReader rs- cmd.ExecuteReader () 7 


// 读 取 记 录 集 
Response.Write ("< center>"); 
Response. Write ("< table border= '1' cellpadding= '0' cellspacing- '1' width= ' 400 ' 
bordercolor- f FFA500> ") ; 
Response.Write ("<tr>"); 
for (int i=0; i«rs.FieldCount; i++) 
Response.Write ("< th align= 'center' height= '30'» "+ rs.GetName (i)+"< /th» ") ; 
Response.Write ("< /tr»") ; 
while (rs.Read()) 
t 
Response.Write ("<tr>"); 
for (int i=0; i«rs.FieldCount; i++) 
Response.Write ("<td align= 'center' height= '30'>"+ rs.GetValue (i)+ "< /td» ") ; 
Response.Write ("< /tr» ") ; 
) 
Response.Write ("< /table»"); 
rs.Close(); 
con.Close(); 
) 


【 例 5-8】 在 站 点 中 添加 一 个 名 称 为 ExcelCon. aspx 的 网 页 ,要求 页 面 连接 App. DataV 
school. xls 工作 敌后 ,将 course 工作 表 以 表格 形式 显示 出 来 。 
主要 程序 代码 如 下 : 


protected void Page Load(object sender, EventArgs e) 
t 
// 创 建 连 接 对 象 
String str= "provider-Microsoft.Jet.OLEDB.4.0;data source= "+ Server.MapPath ("App Data/ 
School.xls")- ";Extended properties=Excel 8.0"; 
OleDbConnection con- new OleDbConnection (str); 
con.Open () ; 
// 创 建 命令 对 象 
String sql- "select * from [course$ ]"; 
OleDbCommand cmd- new OleDbCommand (sql, con); 


// 创 建 oleDbpataReader 对 象 ,返回 一 个 记录 集 

OleDbDataReader rs= amd.ExecuteReader () ; 

// 读 取 记 录 集 中 的 记录 

Response.Write ("< table border= '1' align= 'center' with= '300'»«tr»"); 
for (int i=0; i<rs.FieldCount; i++) 

{ Response.Write ("<td align= 'center'> "+ rs.GetName (i) "« /td»"); } 
Response.Write ("< /tr>"); 
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while (rs.Read()) 

t 
Response.Write ("<tr>"); 
for (int i=0; i«rs.FieldCount; i++) 
{Response.Write ("<td align= 'center'» "* rs.GetValue (i)+"< /td» ") ; } 
Response.Write ("< /tr» ") ; 

} 

Response.Write ("< /table»"); 

rs.Close(); 

con.Close(); 

) 


利用 Connection, Command, DataReader 对 象 可 以 对 数据 源 进行 插入 修改、 删除 和 浏 
WERE, fH DataReader 对 象 使 用 “连接 定向 传输 模式 ”, 当 用 户 要 求 访问 数据 源 时 ,必须 经 
过 宛 长 的 连接 操作 ,当前 用 户 会 锁定 数据 源 ,其 他 用 户 无 法 访问 该 数据 源 。 


5.5 使 用 DataAdapter 对 象 


数据 适配器 (DataAdapter 对 象 ) 表 示 一 组 数据 命令 和 一 个 数据 库 连接 ,它们 用 于 填充 
DataSet 和 更 新 数据 库 。DataAdapter 对 象 是 连接 DataSet 和 数据 库 的 桥梁 , 它 经 常 和 
DataSet 配合 使 用 。DataAdapter 对 象 使 用 Fill. 0 〇 ) 方 法 将 数据 库 中 的 数据 装 入 DataSet 中 ， 
通过 Update () 方 法 将 DataSet 中 的 数据 更 新 到 数据 库 中 。 图 5-7 说 明了 DataAdapter 对 
象 与 DataSet 数据库 之 间 的 关系 。 


DataSet 
DataTable 


DataTable 
DataTable PTS 


5-7 DataAdapter XJ $& 5j DataSet, 数据 库 之 间 的 关系 


DataAdapter Connection} $ | 


1. 创建 DataAdapter 对 象 


SglDataAdapter 对 象 名 =new Sql DataAdapter ("查询 命令 ", 连 接 对 象 ); 
OleDbDataAdapter 对 象 名 =new OleDbDataAdapter ("查询 命令 ", 连 接 对 象 ); 


SQL Server 数据 库 使 用 SqlDataAdapter 类 ,Access 数据 库 使 用 OleDbDataAdapter 类 。 
例如 : 


SqlDataAdapter adapter- new SqlDataAdapter ("select * from student", con); 


2. DataAdapter 对 象 的 属性 
DataAdapter 对 象 的 常用 属性 如 表 5-7 所 示 。 


表 5-7. DataAdapter 对 象 的 常用 属性 
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属 性 说 g 
SelectCommand 获取 或 设置 命令 文本 为 select 语句 的 Command 对 象 
InsertCommand 获取 或 设置 命令 文本 为 insert 语句 的 Command 对 象 
DeleteCommand 获取 或 设置 命令 文本 为 delete 语句 的 Command 对 象 
UpdateCommand 获取 或 设置 命令 文本 为 update 语句 的 Command 对 象 


例如 : 
SqlDataAdapter adapter- new SqlDataAdapter ("select * from student", con); 
可 写成 


SqlCommand cmd- new SqlCommand ("select * from student", con) ; 
SqlDataAdapter adapter- new SqlDataAdapter () ; 
adapter.SelectCommand- cmd; 


3. DataAdapter 对 象 的 方法 

假定 DataAdapter 对 象 为 adapter, 则 其 方法 有 以 下 两 个 。 
(D FIO 

格式 如 下 : 


adapter.Fill (DataSet 对 象 , " 表 名 "); 


功能 : 将 适配器 对 象 指定 的 查询 结果 存 入 数据 集 (DataSet) 的 指定 表 名 中 。 

若 DataSet 已 存在 指定 的 表 名 , 则 将 查询 结果 追加 到 指定 表 名 的 后 面 ; 若 DataSet A ff 
在 指定 的 表 名 , 则 创建 一 个 。 

(2) UpdateO 

格式 如 下 : 


adapter.Update (DataSet 对 象 , " 表 名 "); 


功能 : 用 数据 集 (DataSet) 的 指定 表 去 更 新 适配器 对 象 指定 的 数据 表 。 

说 明 ; 执行 命令 对 象 的 方法 之 前 ,必须 打开 连接 对 象 ;执行 适配器 对 象 的 方法 之 前 ,无 
须 打 开 连 接 对 象 。 

【 例 5-9】 在 站 点 中 添加 一 个 名 为 DataAdapter. aspx 的 网 页 ,要求 在 页 面 上 放置 1 个 
DataGrid 控件 (控件 属性 设置 见 表 5-8) , 当 加 载 页 面 时 ,利用 DataGrid 控件 将 student d f 


的 记录 以 表格 形式 显示 出 来 。 
表 5-8 设置 DataGrid 控件 的 属性 
属 性 设置 值 属 性 设置 值 
CellPadding 3 font-size 10pt 
CellSpacing 1 HorizontalAlign Center 


主要 程序 代码 如 下 : 
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protected void Page Load(object sender, EventArgs e) 


t 


// 创 建 连接 对 象 

String str-"server- localhost;uid- sa;pwd- ;database- stu; Trusted Connection- no"; 
SglConnection con-new SglConnection (str); 

// 创 建 数据 集 对 象 与 适配器 对 象 

DataSet DS-new DataSet () ; 

SqlDataAdapter adapter- new SqlDataAdapter ("select * from student", con); 

// 将 适配器 对 象 指定 的 查询 结果 置 人 数据 集 对 象 的 指定 表 名 中 

adapter.Fill(DS, "student"); 

gridl.DataSource-DS.Tables [0] 

gridl.DataBind(); // 将 数据 源 绑 定 到 服务 器 控件 中 


5.6 使 用 DataSet 对 象 访 问 数 据 库 


DataSet 对 象 是 ADO. NET 的 核心 ,代表 内 存 中 的 一 个 数据 库 , 它 可 以 存储 多 个 表 以 及 


各 表 间 的 关系 。 


利用 Connection, DataAdapter, DataSet 对象 也 可 以 对 数据 源 进 行 插入 、 修 改 . 删 除 和 浏 


览 操作 。DataSet 对 象 使 用 “无 连接 传输 模式 ”, 当 用 户 要 求 访问 数据 源 时 ,无 须 经 过 宛 长 的 
连接 操作 ,而且 数 据 由 数据 源 读 人 DataSet 对 象 之 后 , 便 关闭 数据 连接 ,解除 数据 源 的 锁定 ， 
其 他 用 户 可 以 再 次 使 用 该 数据 源 ,用 户 之 间 无 须 争夺 数据 源 。 


每 个 用 户 都 拥有 专属 的 DataSet 对 象 ,所 有 对 数据 库 的 操作 都 在 DataSet 对 象 中 进行 ， 


与 数据 库 无 关 。 
5.6.1 DataSet 对 象 的 结构 


DataSet 对 象 的 结构 如 图 5-8 所 示 。 


DataSet 


Tables 


[— Tables [0] 
!— Tables [1] 
Rows 
t— Rovs [0] 
Rows [1] 
Columns 
Colunns [0] 
Columns [1] 


图 5-8 DataSet 对象 的 结构 图 


一 个 DataSet 对 象 包含 一 个 Tables 集合 ,Tables 集合 用 于 存放 DataSet 对 象 的 所 有 数 


HEK, Tables i JARE i 号 数据 表 , 每 个 数据 表 都 是 一 个 DataTable 对 象 。 


每 个 数据 表 包 含 一 个 Rows 集合 和 一 个 Columns 集合 。Rows 集合 用 于 存放 数据 表 的 
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所 有 表 行 ,Rows[ 让 表示 第 i 行 记录 ,每 个 表 行 都 是 一 个 DataRow 对 象 。Columns 集合 用 于 
存放 数据 表 的 所 有 列 , Columns [i 表示 第 i 列 ,每 个 列 是 一 个 DataColumn 对 象 。 
DataColumn 对 象 的 ColumnName 属性 表示 当前 列 的 列 名 。 

DataSet , DataTable,DataRow , DataColumn, DataRelation 类 位 于 System. Data 命名 空 
间 中 。 


5.6.2 创建 DataSet.DataTable 对 象 
1. 创建 DataSet 对 象 
创建 DataSet 对 象 的 方式 很 简单 ,语法 格式 如 下 : 
DataSet 对 象 名 =new DataSet () ; 
例如 ， 


DataSet DS=new DataSet () 7 
adapter.Fill(DS, "student") ; 


2. DataSet 对 象 的 属性 和 方法 
DataSet 对 象 的 常用 属性 和 方法 见 表 5-9. 

表 5-9 DataSet 对 象 的 常用 属性 和 方法 
属性 和 方法 说 sg 


集合 名 ,用 于 存放 DataSet 对 象 的 所 有 数据 表 

Tables. Count: 获取 DataSet 对 象 所 包含 的 数据 表 个 数 

Tables Tables. Add(DataTable 对 象 ) : 向 DataSet 对 象 中 添加 一 个 数据 表 
Tables. Remove(DataTable 对 象 ) : 删除 DataSet 对 象 中 的 数据 表 
Tables. ClearO : 清除 DataSet 对 象 中 的 所 有 数据 表 


Clear? 清除 DS 中 所 有 数据 表 中 的 记录 ,使 数据 表 成 为 空 表 


3. 创建 DataTable X1 & 
DataTable Xj $& & - new DataTable ("#4 "); 
4. DataTable 对 象 的 属性 和 方法 
一 个 DataTable 对 象 对 应 着 一 个 数据 表 , 其 常用 属性 和 方法 见 表 5-10。 
表 5-10 DataTable 对 象 的 常用 属性 和 方法 
属性 和 方法 说 — Hj 


集合 名 ,用 于 存放 数据 表 的 所 有 表 行 

Rows. Add( 表 行 对 象 ) : 添加 表 行 

Rows. Remove( 表 行 对 象 ) : 删除 数据 表 中 的 某 一 个 表 行 
Rows[i]. DeleteO : 删除 数据 表 中 的 某 一 个 表 行 


Rows 
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续 表 
属性 和 方法 说 明 
Columns 集合 名 ,用 于 存放 数据 表 的 所 有 列 
TableName 获取 或 设置 数据 表 的 名 称 
PiimaryKey 获取 或 设置 数据 表 的 主键 。 设置 数据 表 t 的 主键 的 格式 为 ; 
t. PrimaryKey 王 new DataColumn[ ]{t. Columns[ " F Et "]) 
NewRow() 创建 一 个 表 行 对 象 


特别 地 ,如 果 已 经 为 数据 集 DS 中 的 数据 表 指定 了 主键 字段 , 则 表示 数据 表 某 一 行 的 代 


BH: 


DS.Tables[" 表 名 "] .Rows.Find (主键 值 ) 


DS.Tables["X 4 "] .Rows[ 行 号 ] 


【 例 5-10】 在 站 点 中 添加 一 个 名 称 为 DataTableTest. aspx 的 网 页 ,要求 使 用 
DataTable,DataRow 和 DataColumn 对 象 来 显示 数据 库 stu 中 student 表 中 的 数据 。 
主要 程序 代码 如 下 : 


protected void Page Load (object sender, EventArgs e) 


{ 


// 创 建 连接 对 象 

String str= "Data Source- localhost; Initial Catalog= Stu; Integrated Security- True"; 
SqlConnection con- new SqlConnection (str); 

// 创 建 数据 集 对 象 和 适配器 对 象 

DataSet DS- new DataSet () 7 

SqlDataAdapter adapter- new SqlDataAdapter ("select * from student", con); 
// 将 适配器 对 象 的 查询 结果 置 人 数据 集 的 某 个 表 中 
adapter.Fill(DS,"student"); 

// 通 过 DataTable, DataColumn 和 DataRow 显示 数据 库 中 的 数据 
Response.Write ("< h3» fi Hl DataTable, DataColumn 和 DataRow« /h3» « hr» ") ; 
Response.Write ("< table border-1 cellspacing-0 cellpadding-2» "); 


// 获 取 DataTable X] e 
DataTable myTable- DS.Tables[0]; 
// 显 示 标 题 行 
Response.Write ("< tr bgcolor=# DAB4B4» ") ; 
foreach (DataColumn myColumn in myTable.Columns) 
t 
Response.Write ("< td» "4 myColumn.ColumnName-* "< /td» ") ; 
} 
Response.Write ("< /tr>"); 


// 显 示 记 录 行 
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foreach (DataRow myRow in myTable.Rows) 

{ 
Response.Write ("<tr>"); 
foreach (DataColumn myColumn in myTable.Columns) 
t 

Response.Write ("< td» "+myRow [nyColumn] + "< /td» ") ; 

} 
Response.Write("« /tr> "); 

} 

Response.Write ("< /table> "); 

} 


5.6.3 使 用 DataSet 对 象 访问 数据 库 


利用 DataSet 对 象 不 仅 可 以 显示 数据 表 中 的 记录 ,还 可 对 数据 表 进 行 插入 、 修 改 、 删 除 
操作 ,具体 的 操作 步骤 如 下 : 

(D 创建 连接 对 象 。 

(2) 创建 数据 集 对 象 和 适配器 对 象 。 

(3) 将 适配器 对 象 的 查询 结果 置 和 数据 集 的 某 个 表 中 。 

CD 对 数据 集中 的 指定 表 进 行 插入 、 删 除 、 修 改 操作 。 

(5) 创建 命令 生成 对 象 ,以 便 获得 适配器 对 象 的 InsertCommand DeleteCommand, 
UpdateCommand 属性 值 。 

(6) 用 数据 集 的 指定 表 去 更 新 适配器 对 象 指定 的 数据 表 。 

【 例 5-11】 在 站 点 中 添加 一 个 名 称 为 DS_Update. aspx 的 网 页 ,设计 界面 如 图 5-9 所 
示 , 利 用 Connection、DataAdapter、DataSet 对 象 对 student 表 进 行 插入 ,修改 、 删 除 操作 。 


学 号 ERERRES 


姓名 F 是 名 不 能 加 
性 别 fes OHENEE 
一 <。 


gu ERRET 
系 别 KITEA 
EN 


5-9 例 5-11 设计 界面 


COD 完成 插入 操作 : 用 户 正确 填写 数据 后 ,再 单 击 “ 插 入 ”按钮 。 

(2) 完成 修改 操作 : 对 刚才 插入 的 记录 进行 修改 ,但 不 能 修改 学 号 。 
(3) 完成 删除 操作 : 删除 刚才 插入 的 记录 。 

在 每 种 操作 完成 后 ,要 在 标签 中 显示 “你 已 成 功 *x* 记 录 !1” 的 字样 。 
操作 步骤 如 下 : 

CD 添加 验证 控件 : 如 表 5-11 所 示 。 
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表 5-11 验证 控件 的 类 型 


被 验证 控件 验证 控件 被 验证 控件 验证 控件 
TextBoxl 必需 字段 验证 TextBox3 必需 字段 验证 
TextBox2 必需 字段 验证 TextBox4 必需 字段 验证 
RadioButtonListl 必需 字段 验证 


(2) 将 “修改 "“ 删 除 ? 按 钮 的 CausesValidation 属性 的 值 设置 为 False. 


G) 编写 程序 代码 : 


1. DataSet DS; 


2. SqlDataAdapter adapter; 
3. protected void Page Load(object sender, EventArgs e) 


4. ( 

5 // 创 建 连接 对 象 

6 String str- "server- localhost;uid- sa;pwd- ;database- stu;Trusted Connection- no"; 
d. SqlConnection con- new SqlConnection (str); 

8 // 创 建 数据 集 对 象 与 适配器 对 象 

9 DS- new DataSet (); 


10. adapter- new SqlDataAdapter ("select * from student", con); 
n. // 将 适配器 对 象 指定 的 查询 结果 置 人 数据 集 的 student 表 中 
12. adapter.Fill(DS, "student"); 


13.) 


14. protected void Buttonl Click(object sender, EventArgs e) 


15. ( 


16. ”// 向 数据 集 的 student 表 添 加 新 记录 


1. DataRow r-DS.Tables["student"].NewRow(); ”// 按 student 表 的 结构 创建 一 个 数据 行 对 象 
18. r["sno"]- TextBoxl.Text; 
19. r["sname"]- TextBox2.Text; 
20. r["ssex"]- RadioButtonListl.SelectedValue; 
21. r["sage"]- TextBox3.Text ; 
22. r["sdept"]- TextBox4.Text; 


23. DS.Tables|["student"] .Rows . Add (r); 


24. // 创 建 命令 生成 对 象 ,以 便 获 得 适配器 对 象 的 InsertCommand 属性 值 


25. SqlCommandBui lder builder- new SqlCommandBuilder (adapter) ; 
26. adapter.InsertCommand- builder.GetInsertCommand|(); 

27. — // 用 数据 集 的 student 表 去 更 新 适配器 对 象 指定 的 数据 表 

28. adapter.Update (DS, "student"); 

29. Llabell.Text- "你 已 成 功 插入 记录 1"; 

30. TextBoxl.ReadOnly- true; 

3t.) 


protected void Button2 Click(object sender, EventArgs e) 


i 


// 对 数据 集 的 student 表 进 行 修改 操作 


DS. Tables [" student"]. PrimaryKey- new DataColumn[] ( DS. Tables [" student"]. Columns 


["sno"] 5; 
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String no-TextBoxl.Text; 
DS.Tables ["student"] .Rows.Find (no) ["sname"]- TextBox2 .Text; 
DS.Tables ["student"] .Rows .Find (no) ["ssex"]- RadioButtonListl.SelectedValue; 
DS.Tables ["student"] .Rows.Find (no) ["sage"]- TextBox3.Text; 
DS.Tables ["student"] .Rows.Find (no) ["sdept"]- TextBox4.Text; 
// 创 建 命令 生成 对 象 ,以 便 获得 适配器 对 象 的 UpdateConmand 属性 值 
SqlCommandBuilder builder=new SqlCommandBuilder (adapter) ; 
adapter .UpdateCommand- bui lder .GetUpdateCommand () ; 
// 用 数据 集 的 student 表 去 更 新 适配器 对 象 指 定 的 数据 表 
adapter .Update (DS, "student"); 
Labell.Text=" 你 已 成 功 修改 记录 !"; 

} 


protected void Button3 Click (object sender, EventArgs e) 
t 
// 对 数据 集 的 student 表 进 行 删除 操作 
DS. Tables [" student"]. PrimaryKey- new DataColumn [] ( DS. Tables [" student"]. Columns 


["sno"] ); 
String no- TextBoxl.Text; 
DS.Tables ["student"] .Rows.Find (no) .Delete () ; // 删 除 主键 值 为 no 的 记录 


// 创 建 命令 生成 对 象 ,以 便 获得 适配器 对 象 的 DeleteConmand 属性 值 
SqlCommandBuilder builder- new SqlCommandBuilder (adapter) ; 
adapter.DeleteCommand- bui lder.GetDeleteCommand|() ; 
// 用 数据 集 的 student 表 去 更 新 适配器 对 象 指定 的 数据 表 
adapter .Update (DS, "student"); 
Label1.Text=" 你 已 成 功 删 除 记录 !"; 

} 


程序 说 明 : 第 25、26 行使 用 了 CommandBuilder 对 象 。 如 果 为 适配器 对 象 设置 了 
SelectCommand 属性 ,就 可 以 通过 CommandBuilder 对 象 来 自动 获得 适配器 对 象 的 
InsertCommand DeleteCommand , UpdateCommand 属性 值 。 

在 “SqlCommandBuilder builder— new SqlCommandBuilder( adapter) ; ”语句 中 , adapter 指定 
的 查询 结果 只 涉及 一 个 基 表 , 且 必 须 包 含 主键 字段 。 在 本 程序 中 ,adapter 指定 的 查询 结果 
是 整个 student 表 , 其 主键 字段 是 sno。 

第 28 行 实际 上 是 对 数据 库 执 行 InsertCommand, DeleteCommand 或 UpdateCommand 
属性 指定 的 SQL 语句 。 


57 项 目 实 训 


实 训 1 对 数据 表 进 行 插入 操作 


实 训 目的 

(OD 掌握 连接 对 象 SqlConnection 的 应 用 。 
(2) 掌握 适配器 对 象 SqlDataAdapter 的 应 用 。 
(3) 掌握 数据 集 对 象 DataSet 的 应 用 。 
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OD 掌握 命令 生成 对 象 SqlCommandBuilder 的 应 用 。 


实 训 要 求 
(1) 在 SQL Server 2000 中 创建 数据 库 “ 素 材 A”, 在 其 中 创建 4 个 数据 表 , 表 的 设计 和 
内 容 分 别 如 图 5-10 一 图 5-13 所 示 。 
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(a) (b) 


REEM oosa ”安平 路 22 号 
张 素 妖 oosa ”跃进 路 4 号 
i 696521 ZRA 
读者 姓名 char 10 v Rer — 055 —iihiEtE 
联系 电话 ca 10 v D smi 昌平 街 3 号 
EREPElE char 30 v bici 879590 — 同 平 路 7 号 


(a) (b) 
图 5-11 读者 管理 表 


| mz [mem km [eir 
SEED ue 4 


TIE 


的 到 DEAE ”长度 AFE lsn 

ID int 4 i 
[amn int 4 v 2 i 
| peus int 4 v EE 1 
datetine 8 v EET 1 

datetine 8 v 2007-5-26 T 

int 4 v PIE TM 

(a) 

[Ere TE TESI 
20030000 — 陈诚 123 5 志士 MLY 
[20030202 REFA 123 5 大 专 am» 
[ [20030203 5a 123 x 本 科 amr 
[2003020 — Burg 123 5 本 科 au» 
[20030205 Hiie 123 x* 中 者 ui» 
20030206 AEF — 123 5 硕士 MU 
| 20030207 ES; 123 x 志士 Qu» 
[2050209 — 其 天 奖 123 男 大 专 amp 
20030210 ER — 123 x 本 科 oL» 
2002081 AF 123 5 本 科 uL» 
20030212 。 ”欧阳 德 培 123 男 Tt Qu» 
20030213 RER 1233 男 wi quu 
20030214 E 123 x* gr uu 
20030215 RME 123 男 大 考 uu 
20030216 QEF 123 5 本 科 av 
20030217 WE 123 x *H am» 
20030218 — sed 123 E T am 
zoz A 123 x Wu [C 
2003000 FÆR — 123 x "lI ML 
20030000 AAE 123 3 大 专 eu 
A 数据 类 型 | 长 度 | sem 20030223 — 其 少 康 123 x 本 科 ML 
出 职工 号 avarchar 10 20030024 AA — 123 E 本 科 eu 
#z nvarchar 8 v 20030225 李 昌 伟 123 男 ps au 
| | 密码 ET n v 20030020 — 林 志 坚 123 5 Mt uL 
性 别 2 v 20030227 ÄRE 123 5 ul Qu» 
EE 20030228 HH 123 — 8 xt amp» 
学 历 nvarchar 4 v ommo Six ipa t Fa i> 
fü» na 16 v 20030030 GAM 23 df XR av» 

(a) (b) 


图 5-13 职工 表 
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(2) 创建 一 个 Web 网 站 sx05 ,并 设置 成 虚拟 目录 。 

(3) 在 网 站 中 添加 一 个 名 称 为 sx5_1. aspx 的 网 页 ,设计 界面 如 图 5-14 所 示 , 利 用 
Connection, DataAdapter, DataSet 对 象 对 “职工 表 进 行 插入 操作 。 

HR: 

(D 使 用 CustomValidator 控件 验证 用 户 填写 的 职工 号 是 否 与 职工 表 中 原 有 的 职工 号 
相同 ,车 相同 , 则 显示 “职工 号 已 经 存在 ,请 重 输 1” 的 出 错 信 息 。 

© 当 用 户 输入 的 数据 正确 并 单 击 “ 添 加 ”按钮 后 ,就 能 向 “职工 ” 表 中 添加 一 条 记录 ,并 
在 标签 中 显示 “你 已 插入 一 条 记录 !1” 的 信息 。 


职工 号 — =- 


姓名 E | 
[en em | 
ta (jos Oxmi 
学 历 — (pants M 
| ^ 
简历 
vj 
1 一 一 


E] 
5-14 实 训 1 设计 界面 


实 训 2 以 表格 形式 显示 数据 表 中 的 记录 


实 训 目 的 

(1) 掌握 利用 Table 标记 显示 数据 表 中 记录 的 方法 。 
(2) 掌握 利用 DataGrid 控件 显示 数据 表 中 记录 的 方法 。 
(3) 比较 两 者 的 异同 。 


实 训 要 求 
在 网 站 中 添加 一 个 名 称 为 sx5_2. aspx 的 网 页 ,设计 界面 如 图 5-15 Bros 。 


[ Tesesestm JP Datacrids 示 | 


Eabell] 
| Columnü Columnl Column2 | 
abc abc abc | 
abc | abc abc | 
abc | abc abc | 
abc dc | e | 
abc abc abc | 


535 实 训 2 设计 界面 


ok: 
(1) 第 一 次 加 载 页 面 时 , 仅 显示 “Table 标记 显示 ”“DataGrid 显示 ”按钮 。 
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(2) 当 单 击 *Table 标记 显示 ”按钮 时 ,利用 Connection, Command, DataReader 对 象 和 
Table 标记 将 “书籍 管理 ” 表 以 表格 形式 显示 在 Labell 控件 中 。 此 时 , DataGrid 控件 不 


显示 。 


(3) 当 单 击 “DataGrid 显示 ”按钮 时 ,利用 Connection、DataAdapter、DataSet 对 象 和 
DataGrid 控件 将 “书籍 管理 ” 表 以 表格 形式 显示 出 来 。 此 时 ,Labell 控件 不 显示 。 


实 训 3 分 页 显示 数据 表 中 的 记录 


实 训 目的 
(OD 掌握 连接 对 象 SqlConnection 的 应 用 。 
(2) 掌握 命令 对 象 SqlCommand 的 应 用 。 

(3) 掌握 记录 集 对 象 SqlDataReader 的 应 用 。 
(4) 掌握 分 页 显示 数据 表 中 记录 的 方法 。 


KIER 


(1) 在 网 站 中 添加 一 个 名 为 sx5_3. aspx 的 网 页 ,要 求 分 页 显示 “职工 ” 表 中 的 记录 。 设 


计 界 面 和 运行 界面 如 图 5-16 和 图 5-17 所 示 。 


(2) 若 当前 显示 第 1 页 , 则 首页 .上 一 页 不 显示 超 链接 ; 若 当 前 显示 最 后 一 页 , 则 下 一 


图 5-17 实 训 3 运行 界面 


页 ` 尾 页 不 显示 超 链接 ;规定 每 页 显示 10 条 记录 。 


实 训 提 示 
参考 程序 代码 如 下 : 


protected void Page Load(object sender, EventArgs e) 


t 


Anja eo T] 

RIS | H& | æ | 性别 | E 
图 5-16 实 训 3 设计 界面 

第 ! 页 / 共 3 页 首 页 | 上 一 页 下 一 页 IR 页 
mrs 姓名 密码 性 别 学 历 
20030201 PER 123 E] 博士 
20030202 陈 泽 明 123 男 x* 
20030203 FARR 13 * 本 科 
20030204 BU 123 男 本 科 


String str="server= localhost;uid- sa;pwd- ;database= 素 材 A"; 
SqlConnection con=new SqlConnection (str); 


con.Open (); 


// 统 计 职 工 表 中 的 记录 条 数 count 
String sql= "select count (职工 号 ) from 职工 "; 
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SqlConmand cmd= new SqlCommand (sql, con) ; 
int count- (int) cmd.ExecuteScalar () ; 


// 车 每 页 显示 10 条 记录 , 则 职工 表 可 分 成 pagecount 页 

sql= "selectx from WI"; 

cmd- new SqlCommand (sql, con); 

SqlDataReader rs= cmd.ExecuteReader () ; 

int pagecount; 

if (count $10--0) pagecount- count/ 10; else pagecount- count/ 10+ 1; 


// 设 置 要 显示 的 页 号 page, 将 记录 指针 指向 page 页 的 第 1 条 记录 中 
String pagel- Request ["page"] ; 

int page; 

if (pagel--null) page-1; else page- int.Parse (pagel); 

if (page«1) page-1; 

if (page»pagecount) page- pagecount; 

for (int i-1; i«- (page- 1) * 10*1; i++) 

rs.Read(); 


// 设 置 当 前 页 各 记录 的 内 容 
for (int i-1; i<=10; i++) 
{ 
HtmlTableRow r- new HtmlTableRow(); 
HtmlTableCell[] c=new HtmlTableCell[5]; 
c[0]- new HtmlTableCel1();// 将 数组 各 元 素 初始 化 
c[1]=new Html TableCell(); 
c[2]7 new HtmlTableCell(); 
c[3]» new Html TableCell(); 
c[4]7 new HtmlTableCell (); 
c[0] .InnerHtml- rs ["ÀA T. "] .ToString(); 
c[1] .InnerHtml-rs ["lt 4 "] .ToString(); 
c[2] -InnerHtml- rs [" f] "] .ToString(); 
c[3] .InnerHtml=rs [" 性 别 "] .ToString() ; 
c[4] .InnerHtml=rs[" 学 历 "] .ToString(); 
for (int j=0; j<5; j++) 
{ 
c[j] .Height="20"; 
r.Cells.Add(c[j]); 
r.Cells[j].Align- "center"; 
} 
TABLE] .Rows .AGd (r); 
if(!rs.Read()) break; 


// 设 置 "首页 "|" 上 一 页 "1" 下 一 页 "|" 尾 页 "的 超 链接 
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Labell.Text-page.ToString(); 

Label2.Text-pagecount.ToString(); 

if (page-- 1)Label3.Text- "首页 | 上 一 页 |"; 

else Label3.Text-"«a href= 'sx5 3.aspx?page=1'> 首 页 </a> |<a href- 'sx5 3.aspx? 
page= "+ (page- 1)* "'» E — Jt « /a» | "; 

if (page--pagecount)Label4.Text- "F—J& | Æ Ji"; 

else Label4.Text- "<a href= 'sx5 3.aspx?page-"- (page+ 1)* "> 下 一 页 </a> |<a href= "sxX5 
3.aspx?page="+pagecount+""> 尾 页 </a> "'; 

con.Close(); 


思考 与 练习 


一 、 填 空 题 
1. ADO. NET 对 象 模型 中 有 5 个 主要 的 组 件 , 分 别 是 


`, o 


2. 数据 适配器 (DataAdapter) 表 示 一 组 和 一 个 ,它们 用 于 
和 。DataAdapter 经 常 和 一 起 配合 使 用 。 

3. 执行 的 方法 之 前 ,必须 打开 连接 对 象 ;执行 “的 方法 之 前 ,无 须 打开 
连接 对 象 。 

4. 如 果 为 适配器 对 象 设 置 了 属性 ,就 可 以 通过 对 象 来 自动 获得 适 配 
器 对 象 的 InsertCommand, DeleteCommand , UpdateCommand 属性 值 。 

二 、 简 答题 


1. 简 述 使 用 DataReader 对 象 读 取 数据 库 的 步骤 。 
2. 简 述 使 用 DataSet 对 象 访问 数据 库 的 步骤 。 
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数据 控件 用 于 在 界面 上 显示 数据 。 在 ASP. NET 中 提供 了 几 种 功能 强大 的 数据 访问 控 
件 ,包括 DataGrid .DataList 和 Repeater 等 。 通 过 这 些 数据 控件 ,用 户 可 以 快速 地 开发 基于 数 
据 库 的 应 用 程序 。 本 章 将 介绍 如 何 使 用 DataGrid , DataList 和 Repeater 控件 以 及 数据 绑 定 
技术 。 


。 掌握 使 用 DataGrid 控件 显示 数据 表 的 方法 
。 掌握 使 用 DataList 控件 显示 数据 表 的 方法 
。 掌握 使 用 Repeater 控件 显示 数据 表 的 方法 
。 掌握 简单 服务 器 控件 的 数据 绑 定 


6.1 DataGrid 控 件 


DataGrid 控件 用 于 将 数据 表 中 的 数据 以 表格 形式 显示 出 来 ,同时 支持 分 页 排序 筛选 、 
更 新 记录 等 操作 。DataGrid 控件 虽然 很 复杂 ,但 可 以 依照 功能 将 其 区 分 成 “自动 生成 列 "与 
“手动 指定 列 " 两 种 模式 。 

采用 “自动 生成 列 "模式 还 是 “手动 指定 列 " 模 式 取决 于 AutoGenerateColumns 属性 , 若 设置 
H True ,表示 为 “自动 生成 列 ”, 至 于 哪些 字段 要 显示 出 来 , 则 由 DataGrid 控件 来 决定 ,用 户 只 
需 设置 其 显示 格式 ; 若 设置 为 False ,表示 为 “手动 指定 列 ” ,用 户 必须 自行 设置 要 显示 的 字段 。 

DataGrid 控件 的 声明 格式 如 下 : 


1. «asp: DataGrid runat =" server" ID =" myDataGrid" AutoGenerateColumns =" False" 
HorizontalAlign -"Center" Width ="480px" > 


25 XHeaderStyle Font -Size -"Small" Font -Bold -"True" HorizontalAlign -"Center" 
ForeColor ="FFFFCC"/ > 
3. XItemStyle Font -Size -"Small" ForeColor —'$830099" HorizontalAlign = "Center"/ > 
4. «Columns > 
5. <asp:BoundColumn HeaderText 二 种 类 " DataField 一 零 部 件 种 类 "> 
</asp:BoundColumn > 
6. <asp:BoundColumn HeaderText 二 品牌 " DataField 二 品牌 "> 


</asp:BoundColumn > 


Te </Columns > 

8. </asp:DataGrid > 

由 此 可 见 ,DataGrid 控件 的 属性 分 为 3 类 : 表格 级 属性 ,样式 属性 、 列 级 属性 。 表 格 级 
属性 如 第 工行 中 的 属性 名 : AutoGenerateColumns ;样式 属性 如 第 2 .3 行 的 属性 名 : ForeColor, 


HeaderText。 


DataGrid 控件 共有 7 类 样式 ,如 表 6-1 所 示 。 
表 6-1 DataGrid 控件 的 样式 
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j 于 控制 表格 各 部 分 ( 如 标题 行 数据 行 分 页 块 ) 的 显示 效果 ; 列 级 属性 如 第 5 行 的 属性 名 : 
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样 式 名 解 释 样 式 名 解 m" 
AlternatingltemStyle 交替 数据 行 样式 TtemStyle 数据 行 样式 
EditltemStyle 编辑 数据 行 样式 PagerStyle 分 页 块 样式 
FooterStyle 页 脚 样式 SelectedltemStyle 选择 数据 行 样式 
HeaderStyle 标题 行 样式 


6.1.1 自动 生成 列 


1. DataGrid 控件 的 分 页 显示 
当 数 据 很 多 ,在 一 页 中 不 能 完全 显示 时 就 需要 进行 分 页 显示 。DataGrid 控件 提供 的 与 
分 页 有 关 的 属性 .事件 如 表 6-2 所 示 。 
表 6-2 与 分 页 有 关 的 属性 .事件 


属性 与 事件 LE 

AllowPaging 决定 是 否 进行 分 页 显示 ,默认 为 false 

PageSize 设置 每 页 显示 的 记录 条 数 , 默 认为 10 

PageCount 获取 整个 DataGrid 控件 占用 的 页 数 ( 只 读 属 性 ) 

CurrentPageIndex 设置 当前 要 显示 的 页 数 ,默认 为 0 
当 单 击 分 页 块 的 页 码 时 ,就 会 自动 提交 并 触发 该 事件 

OnPageIndexChanged 事件 参数 类 为 DataGridPageChangedEventArgs, 它 含有 NewPageIndex 属性 ,用 
于 获取 新 页 码 


【 例 6-1】 在 站 点 中 添加 一 个 名 为 DataGrid_Paging. aspx 的 网 页 ,要 求 能 分 页 显示 “有 零 
部 件 报价 表 ” 的 记录 ,每 页 显示 10 条 记录 ,并 允许 用 户 选择 分 页 显示 的 模式 。 运 行 界面 如 
图 6-1 所 示 。 


计算 机 零 部 件 报价 系统 
规格 价格 | 报价 日 期 

主板 。 华硕 ASUSATM266 — 4800 2002.3.2500000 wwwacuscomtw 
主板 MË  ABITKRTA-RAID 5200 2002.3.3000000 www sbitcomtw 
主板 HE GigaByte GA-TVTXH. 3300 2002-3-30 0:00:00 www gigsbyte.com tw| 
主板 Hi ABITKGO? —— 3800200232000000 wwwabitcomtw 
华硕 。 ASUSATVIS3 — 43002002.32000000 wwwasuscomtw 
主板 ME MSIMS-KTNAQUPro 5200 2002-3-31 00000 www msicom tw 
主板 HE GigaByte GA-TDXR 3900 2002-3-31 0:00:00 www gigabyte com tw, 
主板 ME MSIL MS-K7T266 Pro 3200 2002-3-31 00000 www msicomtw 
主板 Ñ ASUS ATVILYMIWOA 3500 2002-3-1 00000 wwwasuscomtw 
主板 HE GigaByte GA-IZMMH 2800 2002-3-5 0.0000. www gigsbyte.com tw| 


THER: ORFE O 上 下 页 模式 
图 6-1 例 6-1 运行 界面 
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mc Rm 
设计 步骤 如 下 : 
(1) 创建 Access 数据 库 factory. mdb ,在 其 中 创建 “ 零 部 件 报价 表 "“ 通 讯 短 "两 个 表 ， 
如 表 6-3 和 表 6-4 所 示 。 
X63 零 部 件 报价 表 

5 |F Ha 规格 格 报价 日 厂商 信息 
murs 华硕 ASUS ATM266 4800 2002-3-25| www. asus. com, tw 
302 主板 升 技 ABIT KRTA-RAID 5200 2002-3-30| www. abit. com. tw 
303 主板 iix GigaByte GA-TVTXM 3300 2002-3-30| www. gigabyte. co 
304 主板 3H& ABIT KGT 3800 2002-3-20| www abit. com. tw 
305 主板 ejm ASUS ATV133 4300|  2002-3-20| www. asus. com. tw 
306 主板 RE MSI MS-KTN420 Pro 5200 2002-3-31 |www. msi. com. tw 
307 主板 ix GigaByte GA-TDXR 3900 2002-3-31| www. gi gabyte. co 
308 主板 RE MSI MS-KTT266 Pro 3200| 2002-3-31 | www. msi. com. tw 
309 X48 华硕 ASUS ATVI-VIM/WOA 3500 2002-3-1| www. asus. com. tw 
310| 主 板 ix GigaByte GA-TZMK 2800 2002-3-5| www. gigabyte. co 
311 CPU Intel Pentium 4 2GHz 14500| ^ 2002-3-15|www. intel. com. t 
312/CPV Intel Celeron 1.26 | 3500| 2002-3-15| www. intel. com. t 
313|CPU — Intel Pentium III lGHz | 5000| — 2002-3-15 www. intel. com. t 

. SICPU [AMD [AthlonXP 1600+ — | 4200 2002-3-1 www amd. com — 
315| CPU AND AthlonXP 1900+ 9100 2002-3-1 |www. amd. com 
316 内存 创见 Transcend 512MB DI 6300 2002-3-10| www. transcend. c 
317 内 存 胜 创 Kingmax 256MB DIRE 2950 2002-3-10| www. kingmax. com 
318 AF 人 金士顿 Kingston 256MB DDF 2850 2002-3-15| www. kingston. co 
319 AF 创见 Transcend 256MB DI 3040 2002-3-15| www. transcend. c 
320 AF 胜 创 Kingmax 256MB DDRS 3200 2002-3-15| www. kingnax. com 
321| 显 卡 | 华硕 ASUS AGP-V8200 Ti 13000 2002-3-1 |www. asus. com. tul 
322 BF ma Leadtek WinFast Ge 14000 2002-3-1 |www. leadtek. com 
3238F Mé Leadtek WinFast Ge 3300 2002-3-1 |www. Leadtek. com| 
324 显卡 华硕 ASUS V3800 M64 1800 2002-3-1 |www. asus. com. tu| 
325| 硬 盘 Western Digital Western Digital Ca 8000 2002-3-10| www. wde. com 
326| 硬 盘 IBM IBM Deskstar BOGXF| 4300|  2002-3-10| www. ibm. com. tw 
327| 硬 盘 Western Digital Western Digital Cs 4000 2002-3-10| www. wde. com 
328 | 硬盘 Western Digital'Western Digital Cs 2900 2002-3-10| www. wde. com 
329 硬盘 IBN IBM Deskstar 1206X 7350 2002-3-10| www. ibm. com. tw | 

| 380g m88 Uk  |ViewSonie VE1TO | — 28000| ^ — 2002-3-5 www viewsonic. c 
331 显示 器 “| 中 强 CTX PVT20A |... 22500 2002-3-5 www. ctx. com. tw 
332 显示 器 — MK ViewSonic VPl4O | 9500 2002-3-1 | www viewsonic. c 
333 显示 器 Pig CTX PV520 12900 2002-3-5 www. ctx. com. tw 
334 打印 机 惠普 H LaserJet 1100A 13500 2002-4-1 |www. hp. com, tw 
335 打印 机 | Canon. Canon LBP-800 8500 2002-4-1| www. abico. com. t 
336 fTEDWL EPSON EPSON EPL-5800 12500 2002-4-1| www. epson. com. t 
337| 扫 描 仪 Acer Acer S2W 3300U 1700 2002-4-2| waw. acer. com. tw 
338| 扫描 仪 UMAX WAX Astra 3450U 3850 2002-4-1 |www. umax. com. tw 
339289 UMAX WAX Astra 4000U 5400 2002-4-1 |www. umax. com. tw 


E 


日 期 /时 间 


Es 


EE 


表 6-4 EMS 
电话 


1966-8-14 


(04) 2333-2555 


1974-12-T 
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(04) 2541-0347 


1966-6-18 


(04) 2975-0364 


1979-8-29 


(04) 6485-9563 


1972-4-23. 


(04) 2153-0432 


日 期 /时 间 


19T8-12-5 


(02) 2456-3643 


(2) 用 户 界 面 的 主要 代码 如 下 : 


«form ID ="forml" runat -"server" > 
«hi Align "Center" ><span style -"fontsize: 16pt" > 计算 机 零 部 件 报价 系统 «/span ></hl > 


<asp:DataGrid runat -"server" 


文本 


ID-"myDataGrid" HorizontalAlign -"Center" 


AutoGenerateColumns -"True" AllowPaging-"True"  PageSize -"10" 


OnPageIndexChang: 


-"ChangePage" > 


数据 控件 135 
Eo 


<HeaderStyle Font -Size -"Small" Font -Bold ="True" HorizontalAlign -"Center" 


ForeColor -"£FFFCC" BackColor -"$90000"/ > 

XPagerStyle Font -Size -"Small" HorizontalAlign -"Center" 
ForeColor —'830099" BackColor ="$FFFCC"/ > 

XItemStyle Font -Size -"Small" ForeColor ="$30099" /> 


X/asp:DataGrid ><br /> 
«Center > 页 码 模式 : 


<asp:RadioButtonList ID="RadioButtonList1" 

RepeatDirection -"Horizontal" 

<asp:ListItem > 上 下 页 模式 «/asp:ListItem» 
<asp:ListItem > 数字 模式 </asp:ListItem> 


</asp:RadioButtonList > 


</Center > 
</fom> 


(3) DataGrid_Paging. aspx. cs 文件 的 程序 代码 如 下 ; 


void Page Load (Object sender, EventArgs e) 


{ 


if (RadioButtonListl.SelectedIndex --0) 


{ 


myDataGrid.PagerStyle.Mode =PagerMode .NextPrev; 
myDataGrid.PagerStyle.PrevPageText =" 上 一 页 "; 
myDataGrid.PagerStyle.NextPageText =" 下 一 页 "; 


} 


else myDataGrid.PagerStyle.Mode -PagerMode.NumericPages; 


BindList(); 
} 
void BindList () 
í 


String str -"Provider Microsoft . Jet .OLEDB.4 .0; Data Source =" + 
Server .MapPath ("../App_Data/factory.mdb") ; 

OleDbConnection con -new OleDbConnection (str); 

DataSet DS -new DataSet () ; 

OleDbDataAdapter adapter -new OleDbDataAdapter ( 


"select + from 零 部 件 报价 表 ",con) ; 


runat -"server" 
RepeatLayout -"Flow" 


AutoPostBack -"True" > 
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adapter.Fill(Ds, " 零 部 件 报价 表 ") ; 
myDataGrid.DataSource DS; 
myDataGrid.DataBind (); 
} 
protected void ChangePage (Object sender, DataGridPageChangedEventArgs e) 
{ 
myDataGrid.CurrentPageIndex -e.NewPageIndex; 
myDataGrid.DataBind() ; 
) 


程序 说 明 : 当 改变 DataGrid 控件 的 CurrentPageIndex ( 当前 页 号 ) 属性 值 时 ,要 重新 将 
DataGrid 控件 绑 定 到 数据 源 中 。 


2. DataGrid 控件 的 排序 显示 

在 DataGrid 中 可 以 实现 数据 的 排序 。 当 将 AllowSorting 属性 设置 为 rue 时 ,就 启动 
排序 功能 ,此 时 DataGrid 控件 的 所 有 字段 名 就 成 为 排序 按钮 。 当 单 击 “ 排 序 " 按 钮 时 ， 
就 会 自动 提交 并 触发 OnSortCommand 事件 。OnSortCommand 事件 的 语法 定义 如 下 ，; 


protected void DataGridSortCommandEventHandler 
(Object sender, DataGridSortConmmandEventArgs e); 


其 中 , DataGridSortCommandEventArgs 参数 的 SortExpression 属性 表示 的 是 要 进行 排序 的 
字段 名 。 

【 例 6-2】 在 站 点 中 添加 一 个 名 称 为 DataGrid_Ordering. aspx 的 网 页 ,用 于 显示 “ 零 部 件 
报价 表 ” 的 记录 。 当 单 击 某 个 字段 时 , 则 数据 表 按 该 字段 升序 (或 降 
序 ) 显 示 , 若 再 次 单 击 该 字段 , 则 数据 表 按 该 字段 降序 (或 升序 ) 显示 。 
设计 界面 如 图 6-2 所 示 。 

(1) 用 户 界面 的 主要 代码 如 下 : 


<form id ="forml "runat ="server" > 
«div style="text -align:center" > 图 6-2 例 6-2 设计 界面 
«3 > 计算 机 零 部 件 报价 系统 </h3 > 
<asp:DataGrid runat -"server"ID -"myDataGrid"AutoGenerateColumns -"True" 
HorizontalAlign -"Center"AllowSorting -"True" OnSortCommand -"sort" > 
XHeaderStyle Font -Size "Small" Font -Bold-"True" HorizontalAlign -"Center" 
ForeColor ="$FFFCC"BackColor ="990000"/ > 
«pagerstyle Font -Size-"X-Small" HorizontalAlign "Center" 
ForeColor -"$30099"BackColor ="$FFFCC"/ > 
«ItemStyle Font -Size -"Small"ForeColor ="830099"/ > 
X/asp:DataGrid ><br/ > 
«input type -"Hidden"runat ="server"ID ="SortField"value -=" 零 部 件 种 类 " > 
</div> 
</fom> 


(2) DataGrid_Ordering. aspx. cs 文件 的 程序 代码 如 下 : 


1. DataView DV; 
2. protected void Page Load (object sender, EventArgs e) 
3. { 
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4. String str "Provider Microsoft .Jet .OLEDB.4 .0; Data Source =" + 
Server.MapPath (". ./App Data/factory.mdb") ; 
5. OleDbConnection con -new OleDbConnection (str); 
" DataSet DS -new DataSet () ; 
T. OleDbDataAdapter adapter -new OleDbDataAdapter 


("select * from 零 部 件 报价 表 ", con); 
8. adapter.Fill(DS, " 零 部 件 报价 表 ") ; 


9. DV -new DataView (DS.Tables[" 零 部 件 报价 表 "]); 

10. myDataGrid. DataSource =W; 

Lu myDataGrid.DataBind(); 

12. } 

13. protected void sort (Object sender, DataGridSortCommandEventArgs e) 
14. { 

15; if (SortField.Value.EndsWith ("desc") ==false) 

16. SortField.Value -e.SortExpression +"desc"; 
11. else SortField.Value -e.SortExpression t+"asc"; 
18. DV.Sort -SortField.Value; 

19. myDataGrid.DataBind(); 

20. } 


程序 说 明 : 第 9 行为 创建 DataView 对 象 的 语句 ,格式 为 ; 
DataView DV -new DataView (DataTable 对 象 ) ; 


使 用 DataView 对 象 ,可 以 对 数据 表 进 行 筛选 或 排序 , 它 比 select 语句 的 where 子 句 与 
order by 子 句 更 加 灵活 。 

第 18 行 中 的 DV. Son 用 于 设置 要 排序 的 字段 名 , 当 改变 DV. Son 属性 值 时 ,要 重新 将 
DataGrid 控件 绑 定 到 数据 源 中 。 


6.1.2 手动 指定 列 


如 果 要 手动 指定 列 , 首先 要 将 AutoGenerateColumns 属性 设置 为 False, 然后 再 在 
< Columns > 块 中 添加 自 定义 的 列 。DataGrid 控件 可 以 定义 下 面 5 种 列 。 

(1) 绑 定 列 (BoundColumn) : 最 常用 的 列 , 自 动 生成 的 列 均 为 绑 定 列 。 

(2) 超 链接 列 ( HyperLinkColumn) : 每 一 行 均 含有 超 链接 的 列 。 

(3) 模板 列 (TemplateColumn) : 每 一 行 均 含有 模板 的 列 。 

(4) 按钮 列 ( ButtonColumn) : 每 一 行 均 含 有 一 个 自 定义 按钮 的 列 。 

(5) 编辑 列 ( EditCommandColumn) : 每 一 行 均 含 有 3 个 按钮 (“编辑 "“ 更 新 "“ 取 
W”) 的 列 。 


1. 绑 定 列 
绑 定 列 有 下 列 常用 属性 。 
(1) HeaderText ="…" ; 设置 列 标题 所 要 显示 的 文字 。 


(2) DataField =" FRZ": 设置 所 要 显示 的 字段 名 称 。 
【 例 6-3】 在 BoundColumn. aspx 中 实现 BoundColumn 的 应 用 。 
(1) 用 户 界面 的 代码 如 下 : 


«form id ~"foml" runat -"server" > 


«n1 Align "Center" > 计算 机 零 部 件 报价 系统 </hl > 
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<asp:DataGrid runat -"server" ID-"myDataGrid" AllowPaging -"True" 
AutoGenerateColumns -"False" HorizontalAlign -"Center" Width ="480px" > 
XHeaderStyle Font -Size -"Small" Font -Bold-"True" HorizontalAlign -"Center" 
ForeColor ="#FFFFCC" BackColor -"$90000" / > 
XItemStyle Font -Size "Small" ForeColor —'$30099" HorizontalAlign -"Center"/ > 
PagerStyle Font -Size -"Small" HorizontalAlign -"Center" NextPageText = 下 一 页 " 
PrevPageText 一 上 一 页 " /> 
<Columns > 
«asp:BoundColumn HeaderText = 种 类 " DataField =" 零 部 件 种 类 "/ > 
«asp:BoundColumn HeaderText "品牌 " DataField 一 "品牌 "/ > 
<asp:BoundColumn HeaderText = 规格 " DataField "规格 " / > 
«asp:BoundColumn HeaderText "价格" DataField "fri" 
DataFomatString -"(0:c0)" /> 
人 -~-{0:c0} 表 示 将 数值 显示 为 货币 格式 ,第 2 个 0 表示 小 数位 数 , 若 省 略 , 则 默 
认为 2- 避 > 
</Columns > 
</asp:DataGrid > 
</fom> 


(2) BoundColumn. aspx. cs 文件 的 程序 代码 如 下 : 


protected void Page Load (object sender, EventArgs e) 
{ 
String str -"Provider Microsoft .Jet .OLEDB.4.0;Data Source =" + 
Server.MapPath ("../App Data/factory.mdb"); 
OleDbConnection con -new OleDbConnection (str); 
DataSet DS new DataSet () ; 
OleDbDataAdapter adapter -new OleDbDataAdapter 
("select * from 零 部 件 报价 表 ",con) ; 
adapter.Fill(Ds, " 零 部 件 报价 表 ") ; 
myDataGrid.DataSource -DS; 
myDataGrid.DataBind|() ; 
) 


2. 超 链接 列 

超 链接 列 有 下 列 常 用 属性 : 

(1) HeaderText =" ---" ; 设置 列 标题 所 要 显示 的 文字 。 
(2) Text ="…": 设置 超 链接 的 文本 。 


(3) DataTextField =" 字段 名 ": 设置 超 链 接 的 文本 , 若 与 Text 同时 设置 , 则 以 
DataTextField 为 准 。 
(4) DataNavigateUrlField =" FRA": 当 单 击 超 链 接 时 ,就 会 转 去 执行 该 字段 指定 


的 URL。 
【 例 64】 在 HyperLinkColumn. aspx 中 实现 HyperLinkColumn 的 应 用 。 
用 户 界面 的 代码 如 下 : 


1. «form id ='foml "runat ="server" > 
2. «hl Align -"Center" > 计算 机 零 部 件 报价 系统 </hl > 
k <asp:DataGrid runat ="Server"ID -"myDataGrid"AutoGenerateColumns ="False" 
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HorizontalAlign -"Center"Width ="550px" > 
4. XHeaderStyle Font -Size -"Small"Font -Bold -"True"HorizontalAlign -"Center" 
ForeColor -"£FFECC"BackColor -"$90000"/ > 


5. XItemStyle Font -Size -"Small"ForeColor —'$30099"HorizontalAlign -"Center"/ > 

6. «Columns > 

dis <asp:BoundColumn HeaderText 一 种 类 "DataField =" 零 部 件 种 类 "/ > 

8. <asp:BoundColumn HeaderText = 品牌 "DataField=" 品 牌 "/ > 

9. <asp:BoundColumn HeaderText "规格 "DataField —"Hjft"/ > 

10. «asp:BoundColumn HeaderText "价格 "DataField 下 "价格 " 

DataFormatString ="{0:c0}"/> 

1i; <asp:HyperLinkColum HeaderText = 厂商 信息 " DataNavigateUrlField = 厂商 信 
息 " DataNavigateUrlFormatString =" http://(0]" Text =" Click Here" 
DataTextField= 厂 商 信息 " Target = new"/ > 

12. «/Columns > 

13. X/asp:DataGrid > 

14. </fom> 


程序 说 明 : 第 11 行 加 入 HyperLinkColumn , 超 链接 文字 取 自 “厂商 信息 "字段 , 超 链接 地 
址 取 自 “厂商 信息 "字段 , 超 链接 格式 为 :“http://10}” ,表示 超 链接 地 址 以 htp:// 开 头 ， 
101 表 示 取 自由 DataNavigateUrlField 属性 指定 的 字段 ,目标 框架 为 打开 新 窗口 。 

3. 模板 列 

TemplateColumn 是 灵活 性 最 大 的 列 类 型 ,也 是 必须 花 时 间 设 置 的 列 类 型 。 
TemplateColumn 有 下 列 常 用 属性 。 


(1) HeaderText ="…": 设置 列 的 标题 。 
(2) HeaderTemplate: 标题 模板 ,用 来 设置 列 的 标题 , 若 与 HeaderText 同时 设置 , 则 以 
HeaderTemplate 为 准 。 


(3) ItemTemplate: 数据 模板 ,用 来 定义 每 个 数据 行 要 显示 的 数据 ,此 模板 不 能 省 略 。 

(4) EditltemTemplate ; 编辑 数据 模板 ,用 来 定义 在 编辑 模式 下 数据 行 显示 的 数据 , 它 一 
般 包 含 TextBox 控件 。 若 省 略 此 模板 , 则 在 编辑 模式 下 数据 行 仍 使 用 数据 模板 。 

在 模板 中 可 以 加 入 HTML 标记 、 服 务 器 控件 。 在 模板 中 使 用 ASP. NET 变量 时 ,必须 使 
用 <%# 变 量 名 % > 格式 ,例如 : 


<ItemTemplate > «$BataBinder.Eval (Container.DataItem, "字段 名 ")%$ ></ItemTemplate > 


意义 : 执行 数据 绑 定 表达 式 ,并 返回 结果 字符 串 ,Container. Dataltem 表示 当前 数据 行 ， 
也 可 简写 成 < ItemTemplate > < % #Eval(" 字段 名 " )% > < /TtemTemplate > 。 

【 例 6-5】 在 TemplateColumn. aspx 中 实现 TemplateColumn 的 应 用 。 

用 户 界面 的 代码 如 下 : 


<fom id ="foml" runat -"server" > 
«hl Align -"Center" > 计算 机 零 部 件 报价 系统 </hl > 
<asp:DataGrid runat ="server" ID="myDataGrid" AutoGenerateColumns -"False" 
HorizontalAlign -"Center" Width ="550px" > 
<HeaderStyle Font -Size -"Small" Font -Bold ="True" HorizontalAlign -"Center" 
ForeColor ="$FFFCC" BackColor —'$90000" / > 
XItemStyle Font -Size -"Small" ForeColor ="830099" HorizontalAlign ="Center" /> 


139 


140 ASP. NET 网 站 开发 案例 教程 
[EL AL 


«Columns > 
«asp:BoundColumn HeaderText 下 种 类 " DataField =" 零 部 件 种 类 " / > 
<asp:BoundColum HeaderText 下 品牌" DataField "品牌" /> 
«asp:BoundColumn HeaderText = 规格 " DataField "规格 " / > 
<asp:BoundColumn HeaderText 二 价格 " DataField fti" 
DataFormatString-"(0:c0]" /> 
<asp:TemplateColum > 
<HeaderTemplate > 报价 日 期 «/HeaderTemplate > 
<ItemTemplate> «$ £onvert. ToDateTime (DataBinder.Eval 
(Container.Dataltem, "报价 日 期 ")) .ToShortDateString () $ » «/ItentTemplate > 
«/asp:TemplateColumn > 
«/Columns » 
«/asp:DataGrid > 
«/fom» 


4. 按钮 列 

按钮 列 有 下 列 常用 属性 。 

(1) HeaderText =" 列 标题 " : 设置 列 的 标题 。 

(2) Text; 设置 命令 按钮 的 文本 。 

(3) DataTextField: 设置 命令 按钮 的 文本 , 若 与 Text 同时 设置 , 则 以 DataTextField 为 准 。 
(4) ButtonType =" LinkButton/PushButton" ,默认 为 LinkButton 。 


(5) CommandName ="…": 设置 Button 控件 的 命令 名 称 。 
【 例 6-6】 在 ButtonColumn. aspx 中 实现 ButtonColumn 的 应 用 。 
用 户 界面 的 代码 如 下 : 


<form id ="forml" runat ="server" > 
«hl Align "Center" style -"text -align: center" > 计算 机 零 部 件 报价 系统 </hl > 
<asp:DataGrid runat ="server" ID ="myDataGrid" AutoGenerateColumns -"False" 
HorizontalAlign -"Center" Width ="500px" > 
«HeaderStyle Font -Size -"Small" Font -Bold -"True" 
HorizontalAlign -"Center" ForeColor —'£FFFCC" BackColor ="990000"/ > 
XItemStyle Font -Size -"Small" ForeColor ="830099" HorizontalAlign "Center" /> 
«Columns > 
«asp:BoundColumn HeaderText 下 种类" DataField -=" 零 部 件 种 类 " / > 
<asp:BoundColumn HeaderText 下 品牌" DataField 下 "品牌" /> 
<asp:BoundColumn HeaderText 二 规格" DataField 下 "规格 " / > 
<asp:BoundColumn HeaderText "fti" DataField "价格 " 
DataFormatString -"(0:c0)" /> 
«asp:ButtonColumn HeaderText 下 加 入 购物 袋 " Text 二 订购 " 
ButtonType -"LinkButton"/ > 
«/Columns > 
</asp:DataGrid > 
«/form» 


5. 编辑 列 
(1) 编辑 列 的 列 级 属性 
(D HeaderText = " 列 标题 " : 设置 列 的 标题 。 
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@ ButtonType =" LinkButton/PushButton " ,默认 为 LinkButton ,在 代码 声明 块 中 写成 
ButtonColumnType. LinkButton 。 


(3) EditText =" … " : 设置 CommandName 为 Edit 的 按钮 的 文本 。 
@ UpdateText =" …" ; 设置 CommandName 为 Update 的 按钮 的 文本 。 
(5) CancelText =" … " : 设置 CommandName 为 Cancel 的 按钮 的 文本 。 


(2) 与 更 新 记录 有 关 的 DataGrid 控件 的 属性 

(D DataKeyField = "字段 名 " : 设置 关键 字段 ,每 条 记录 的 关键 字段 值 均 放 在 DataKeys 
集合 中 。 

(2) EditltemIndex =n; 获取 或 设置 编辑 行 的 序号 , 若 退 出 编辑 行 , 则 返回 -1。 

(3) 与 更 新 记录 有 关 的 DataGrid 控件 的 事件 


(D OnEditCommand ="…" : 单 击 CommandName 为 Edit 的 按钮 会 触发 该 事件 。 

Q OnUpdateCommand =" ---" : 单 击 CommandName 为 Update 的 按钮 会 触发 该 事件 。 
(3) OnCancelCommand ="…" ; "Hif; CommandName 为 Cancel 的 按钮 会 触发 该 事件 。 
(4) OnDeleteCommand ="…" ; 单 击 CommandName 为 Delete 的 按钮 会 触发 该 事件 。 
(5) OnItemCommand ="…": 单 击 DataGrid 控件 内 的 任何 一 个 按钮 均 会 触发 该 事件 。 


上 述 事件 的 事件 参数 类 均 为 DataGridCommandEventArgs, 含有 如 下 属性 。 

(D CommandName: 获取 按钮 所 指定 的 命令 名 称 。 

@ Item; 获取 单 击 的 按钮 所 在 的 数据 行 ( DataGridItem 对 象 ) 。 

这 里 的 “按钮 "是 指 Button ,ImageButton 或 LinkButton 控件 。 

【 例 6-7】 在 EditCommandColumn. aspx 中 实现 EditCommandColumn 的 应 用 。 
(1) 用 户 界面 的 代码 如 下 : 


<form id ="forml" runat ="server" > 
<asp:DataGrid runat ="server" ID -"Gridl" AutoGenerateColumns -"false" 
HorizontalAlign "Center" Width -"650px" Font -Size -"Smaller" 
OnEditCommand "Edit" OnUpdateConmand -"Update" 
OnCancelCommand -"Cancel" > 
XHeaderStyle Font -Bold-"True" HorizontalAlign -"Center" ForeColor -"£FFFFCC" 
BackColor -"890000" /> 
XItemStyle  ForeColor ="830099" /> 
«Columns > 
«asp:TemplateColumn HeaderText =" 学 号 "> 
XItenTemplate > 
«SpataBinder.Eval (Container.DataItem, "sno")% > 
</ItemTemplate > 
XEditlItemTemplate > 
«SpataBinder.Eval (Container.Dataltem, "sno")$ > 
«/EditlIteniTemplate > 
«/asp:TemplateColumn > 
<asp:BoundColumn HeaderText 一 姓名 " DataField-"sname" > 
<HeaderStyle Width ="100px" / »«/asp:BoundColumn > 
<asp:BoundColum HeaderText = 性 别 " DataField-"ssex" > 
<HeaderStyle Width —"100px" / ></asp:BoundColum > 
<asp:BoundColumn HeaderText = 年龄 " DataField-"sage" > 
<HeaderStyle Width —"100px" / ></asp:BoundColum > 
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<asp:BoundColumn HeaderText 二 系 别 " DataField ="sdept" > 
<HeaderStyle Width ="100px" / » «/asp:BoundColumn > 
«asp: EditCommandColumn EditText 一 编辑 "CancelText 一 取消 " UpdateText 一 更 新 " 
HeaderText 一 "编辑 " > 
</asp:EqitComnmandColumn > 
</Colums > 
</asp:DataGrid > 
</fom> 


(2) EditCommandColumn. aspx. cs 文件 的 程序 代码 如 下 : 


SqlDataAdapter adapter; 

DataSet DS; 

protected void Page Load (object sender, EventArgs e) 

OO ABERA 
String strcon ="server -localhost;uid =sa;pwd =; database =stu; Trusted Connection -no"; 
SqlConnection con =new SqlConnection (strcon) ; 
// 创 建 适 配器 对 象 与 数据 集 对 象 
adapter new SqlDataAdapter ("select * from student",con); 
DS -new DataSet () ; 
// 将 适配器 对 象 的 查询 结果 置 人 数据 集 的 student 表 中 
adapter.Fill(DS, "student") ; 
Gridl.DataSource =DS; 
if (! Page. IsPostBack) Gridl.DataBind(); 


// 进 入 数据 编辑 模式 
protected void Edit (Object sender, DataGridCommandEventArgs e) 


Gridl.EditItemIndex -e.Item.ItemIndex; 
Gridl.DataBind(); 


// 退 出 数据 编辑 模式 
protected void Cancel (Object sender, DataGridCommandEventArgs e) 


Gridl.EditItemIndex =-1; 
Gridl.DataBind(); 


// 更 新 数据 
protected void Update (Object sender, DataGridCommandEventArgs e) 


String name =( (TextBox) e. Item.Cells [1] .Controls [0] ) .Text; 
String sex -((TextBox) e.Item.Cells[2] Controls [0]) .Text; 
String age -((TextBox) e. Item.Cells [3] .Controls[0]) .Text; 
String dept =( (TextBox) e. Item.Cells [4] .Controls [0] ) . Text; 
int row=e.Item.ItemIndex;//e-Item 返 回 单 击 的 按钮 所 在 的 数据 行 
DS.Tables ["student"] .Rows [row] [1] name; 

DS.Tables ["student"] .Rows [row] [2] =sex; 

DS.Tables ["student"] .Rows [row] [3] =age; 

DS.Tables ["student"] .Rows [row] [4] =dept; 

// 创 建 命令 生成 对 象 , 以便 获得 adapter 的 UpdateConmand 属性 的 值 
SqlConrmandBui lder builder new SqlCommandBuilder (adapter) ; 
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adapter .UpdateConmand -uilder.GetUÜpdateCommand () ; 
// 用 数据 集 的 student 表 去 更 新 适配器 对 象 指 定 的 数据 表 
adapter Update (DS, "student") ; 
DS.Clear(); 
// 将 适配器 对 象 指定 的 查询 结果 置 人 数据 集 的 student 表 中 
adapter .Fill (DS, "student") ; 
Gridl.DataSource =DS; 
Gridl .EqitItemIndex =-1; 
Gridl.DataBind(); 
} 


当 改 变 DataGrid 控件 的 CurrentPageIndex ( 当前 页 号 ) .EditltemIndex( 编辑 行 序号 ) 属性 


值 时 ,都 要 重新 将 DataGrid 控件 绑 定 到 数据 源 中 。 


单 击 DataGrid 控件 中 某 一 行 CommandName 为 Edit 的 按钮 时 ,该 行 就 进入 编辑 模式 ,所 有 


的 绑 定 列 都 可 以 编辑 ,模板 列 在 指定 编辑 数据 模板 时 也 可 以 编辑 ,但 其 他 类 型 的 列 不 能 编辑 。 


【 例 6-8】 在 站 点 中 添加 一 个 名 称 为 integrate. aspx 的 网 页 ,要求 利用 DataGrid 控件 实 


现 对 student 表 的 修改 ,删除 等 操作 ,运行 界面 如 图 6-3 所 示 。 


E63 例 6-8 运行 界面 


(1) 用 户 界 面 的 代码 如 下 : 


<form id ="forml" runat ="server" > 
<div style ="text -align: center" > 
«bà > 对 数据 表 进行 修改 、 删 除 操作 </h4 > 
<asp:DataGrid AutoGenerateColumns -"False" ID -"Gridl" runat -"server" 
OnEditConmand -"Edit" OnCancelCommand -"Cancel" OnUpdateCommand "Update" 
OnDeleteCommand -"Delete" width ="480" Font -Size -"Small" 
HorizontalAlign -"Center" CellSpacing -"1" > 
XHeaderStyle Height —"20px"/ > 
«ItenStyle Height ="20px" /> 
«Columns > 
«asp:TemplateColumn HeaderText =" 学 号 "> 
XItenTemplate > «$&£val ("sno")$ » «/itemtemplate > 
«EditltenTemplate > «asp: TextBox ID -"sno" runat -"server" Columns -"6" Text -' &&£val 
("5no*)$5* /> 
«/EditIteniTemplate > 
«/asp:TemplateColumn > 
«asp:TemplateColumn HeaderText 二 姓名 "> 
XItentTemplate > «&£val ("sname") $ ></ItemTenplate > 
«EditlteniTemplate > «asp:TextBox ID -"'sname" runat -"server" Columns -"6" 
Text -' &Eval ("sname") $ >'/> 
«/EditItenTemplate > 
«/asp:TemplateColumn > 
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«asp:TemplateColumn HeaderText 一 性别" > 
XItenTemplate > «&£val ("ssex")$ ></ItemTerplate > 
<EditItemTenplate ><asp:TextBox ID -"ssex" runat -"server" Columns -"6" Text -' Eval 
("ssex")$»' /> 
«/FditItenfTemplate > 
«/asp: TemplateColumn > 
«asp:TemplateColumn HeaderText "$" > 
XItenTemplate > &£val ("sage") $ ></ItemTemplate > 
«EditIten(Template > <asp:TextBox ID="sage" runat -"server" Columns -"6" Text -' «&£val 
("sage")$»' /> 
«/EditItenTemplate > 
X/asp:TemplateColumn > 
«asp:TemplateColumn HeaderText "JI" > 
<TtenTemplate > «&£val ("sdept") $ » «/TteniTemplate > 
«EditItenTemplate > «asp:TextBox ID -"sdept" runat -"server" Columns -"6" 
Text -' «val ("sdept")$»' /> 
«/EditItenTemplate > 
«/asp: TemplateColumn > 
«asp:TemplateColumn HeaderText 二 编辑 " > 
4ItemTemplate »«asp:LinkButton ID-"LinkButtonl" runat="server" Text "it" 
ConmandName -"Edit"/ > 
«/IteniTemplate > 
«EditItemTemplate > 
«asp:LinkButton ID-"LinkButton2" runat="server" Width-"5" Text 二 更 新 " 
ConmandName "Update" / > 
«asp:LinkButton ID-"LinkButton3" runat="server" Width-"5" Text "WBR" 
ConmandName -"Delete" /> 
«asp:LinkButton ID-"LinkButtond" runat="server" Width-"5" Text = 取消 " 
ConmandName -"Cancel"/ > 
«/EditIteniTemplate > 
«HeaderStyle Width -"80px" / > 
«/asp:TemplateColumn > 
«/Columns > 
«/asp:DataGrid» 
</fom> 


(2) integrate. aspx. cs 文件 的 程序 代码 如 下 : 


SqlDataAdapter adapter; 

DataSet DS; 

protected void Page Load (object sender, EventArgs e) 

í 
// 创 建 连接 对 象 
String strcon "server -localhost;uid -5a;pwd =; database -stu;Trusted Connection -no"; 
SqlConnection con new SqlConnection (strcon); 
// 创 建 适配器 对 象 与 数据 集 对 象 
adapter -new SqlDataAdapter ("select * from student",con); 
DS new DataSet () ; 
// 将 适配器 对 象 指 定 的 查询 结果 置 人 数据 集 的 student 表 中 
adapter.Fill(DS, "student") ; 
Gridl.DataSource 3D; 
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if (! Page.IsPostBack) Gridl.DataBind(); // 第 一 次 调用 


// 进 入 数据 编辑 模式 
protected void Edit (Object sender, DataGridCommandEventArgs e) 


Gridl.EditItemIndex -e.Item.ItemIndex; 
Gridl.DataBind(); 


// 退 出 数据 编辑 模式 
protected void Cancel (Object sender, DataGridCommandEventArgs e) 


Gridl.EditItemIndex =-1; 
Gridl.DataBind(); 


// 删 除数 据 
protected void Delete (Object sender, DataGridCommandEventArgs e) 


DS.Tables ["student"] .Rows [e. Item. ItemIndex] .Delete () ; 

// 创 建 命令 生成 对 象 , 以便 获得 adapter 的 DeleteCommand 属性 的 值 
SqlConmandBuilder builder -new SqlCommandBui lder (adapter) ; 
adapter .DeleteCommand -builder.GetDeleteCommand () ; 

// 用 数据 集 的 student 表 去 更 新 适配器 对 象 指定 的 数据 表 

adapter Update (DS, "student") ; 

DS.Clear(); 

adapter.Fill(DS, student"); 

Gridl.DataSource =DS; 

Gridl.DataBind(); 


) 
// 更 新 数据 
protected void Update (Object sender, DataGridCommandEventArgs e) 


{ 


// e.Item: 返回 单 击 的 按钮 所 在 的 数据 行 
int row =e.Item. ItemIndex; 
/ [FindControl (id) :在 容器 控件 中 搜索 标识 为 ia 的 控件 
DS.Tables ["student"] .Rows [row] ["sno"] =( (TextBox)e. Item.FindControl ("sno")) .Text; 
DS .Tables ["student"] .Rows [row] ["sname"] = 
( (TextBox)e.Item.FindControl ("sname")) . Text ; 
DS.Tables ["student"] .Rows [row] ["ssex"] =( (TextBox)e.Item.FindControl ("ssex")) . Text; 
DS.Tables ["student"] .Rows [row] ["sage"] -((TextBox) e. Item.FindControl ("sage")) .Text; 
DS.Tables ["student"] .Rows [row] ["sdept"] — 
((TextBox) e. Item. FindControl ("sdept")) .Text; 
SqlCommandBuilder builder -new SqglCommandBuilder (adapter); 
adapter .UpdateConmand -builder.GetUpdateConmand () 7 
// 用 数据 集 的 student 表 去 更 新 适配器 对 象 指定 的 数据 表 
adapter Update (DS, "student") ; 
DS.Clear(); // 清 除 DS 中 所 有 表 的 所 有 行 
adapter.Fill(DS, "student"); 
Gridl.DataSource -DS; 
Gridl.DataBind(); 


6.2 Datalist 控件 


DataList 是 一 个 模板 控件 , 它 使 用 模板 将 数据 表 中 的 数据 显示 出 来 ,并 且 可 以 对 记录 进 
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行 删除 、 更 新 等 操作 。 


6.2.1 DataList 控件 的 模板 


DataList 控件 支持 7 种 模板 ,每 种 模板 可 以 设置 各 自 的 样式 , 见 表 6-5。 


表 6-5 各 种 模板 对 应 的 样式 


BOO 对 应 的 样式 BOO 对 应 的 样式 
HeaderTemplate HeaderStyle FooterTemplate FooterStyle 
TtemTemplate TtemStyle EditltemTemplate EditltemStyle 


AlternatingltemTemplate 


AlternatingltemStyle 


SelectedItemTemplate 


SelectedItemStyle 


SeparatorTemplate 


SeparatorStyle 


(1) HeaderTemplate ; 页 眉 模板 ,用 来 定义 DataList 控件 的 标题 。 

(2) ItemTemplate: 数据 模板 ,用 来 定义 每 个 数据 行 要 显示 的 数据 ,此 模板 不 能 
省 略 。 

(3) AlternatingItemTemplate: 隔行 数据 模板 ,用 来 定义 隔行 显示 的 数据 。 如 果 设 置 了 此 
模板 , 则 奇数 行 数据 会 应 用 数据 模板 ,偶数 行 数据 应 用 隔行 数据 模板 。 

(4) SeparatorTemplate ; 分 隔 模板 ,定义 两 行 数据 之 间 如 何 分 隔 。 

(5) FooterTemplate; 页 脚 模板 。 

(6) EditltemTemplate ; 编辑 数据 模板 ,用 来 定义 在 编辑 模式 下 数据 行 显示 的 数据 , 它 一 
般 包含 TextBox 控件 。 若 省 略 此 模板 , 则 在 编辑 模式 下 数据 行 仍 使 用 数据 模板 。 

(7) SelectedltemTemplate; 选择 数据 模板 ,用 来 定义 选择 某 个 数据 行 时 将 显示 的 数据 。 


6.2.2. DataList 控件 的 属性 和 事件 


1. DataList 控件 的 属性 

(1) DataKeyField =" FRA" : 设置 关键 字段 ,每 条 记录 的 关键 字段 值 均 放 在 DataKeys 
集合 中 。 

(2) EditltemIndex =n; 获取 或 设置 编辑 行 的 序号 , 若 退出 编辑 行 , 则 返回 - 1。 

(3) ExtractTemplateRows = true/false; 默认 为 false。 设 置 当 各 模板 包含 Table 控件 时 ， 
是 否 将 所 有 Table 控件 合并 成 一 个 。 若 取 true, 则 所 有 模板 都 必须 包含 结构 完整 的 Table 控 
件 , 和 否则 会 产生 错误 。 

(4) GridLines: 设置 当 RepeatLayout = Table 时 ,DataList 控件 的 网 格 线 样 式 。 


2. DataList 控件 的 事件 


(1) OnEditCommand =" ---" : 单 击 CommandName 为 Edit 的 按钮 时 会 触发 该 事件 。 

(2) OnUpdateCommand ="…" : 单 击 CommandName 为 Update 的 按钮 时 会 触发 该 
事件 。 

(3) OnCancelCommand =" …" ; 单 击 CommandName 为 Cancel 的 按钮 时 会 触发 该 
事件 。 

(4) OnDeleteCommand ="…" : 单 击 CommandName 为 Delete 的 按钮 时 会 触发 该 事件 。 


上 述 事 件 的 事件 参数 类 均 为 DataListCommandEventArgs ,含有 如 下 属性 。 
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(1) CommandName; 获取 按钮 所 指定 的 命令 名 称 。 
(2) ltem; 获取 单 击 的 按钮 所 在 的 数据 行 ( DataListltem 对 象 ) 。 
【 例 6-9】 在 站 点 中 添加 一 个 名 称 为 DataList. aspx 的 网 页 ,要求 利用 DataList 控件 实现 
对 “通讯 短 " 表 的 修改 .删除 等 操作 ,运行 界面 如 图 64 所 示 。 


HET 1966-8-14 (04) 2333-2555 
林 怡 君 1974-12-7 (04) 2541-0347 
黄 丽 补 1966-6-18 (04) 2975-0364 
TS 1979-8-29 (04) 6485-9563 
Ew 1972-4-23 (04) 2153-0432 
bi 1979-12-5 (02) 2456-3643 

图 64 例 6-9 运行 界面 


(1) 用 户 界面 的 代码 如 下 : 


<form id "fom "runat ="server" > 
«hl align ="center" JMM EMRA </hl > 
<asp:DataList runat ="server" ID-"myDataList" CellPadding ="3" Width ="500" 
RepeatColumns ="1" Border ="1" BorderColor-"Blue" HorizontalAlign ="Center" 
OnEditCommand -"Edit" OnUpdateCommand -"Update" OnDeleteCommand -"Delete" 
OnCancelCommand -"Cancel" CellSpacing -"1" ExtractTemplateRows -"True" > 
<HeaderTenplate > 
«asp:Table ID -"Tablel" runat -"server" Width -"500" GridLines -Both > 
Xasp:TableRow ID -"TableRowl" runat -"server" > 
«asp:TableCell ID -"TableCelll" runat -"server" Width —"100" > 
姓名 
</asp:TableCell > 
<asp:TableCell ID -"TableCell2" runat ="server" Width ="100" > 
生日 
</asp:TableCell > 
<asp:TableCell ID -"TableCell3" runat ="server" Width ="200" > 
电话 
</asp:TableCell > 
<asp:TableCell ID="TableCell4" runat ="server" Width ="100" > 
编辑 
</asp:TableCell > 
</asp:TableRow > 
</asp:Table > 
</HeaderTemplate > 
<ItemTemplate > 
<asp:Table ID-"Table2" runat="server" Width="500" BorderColor -"blue" 
GridLines æoth > 
<asp:TableRow ID ="TableRow2" runat -"server" HorizontalAlign ="Center" > 
<asp:TableCell ID="TableCell5" runat -'server" > 
«$:BataBinder.Eval (Container .DataItem, "姓名 ")$ > 
</asp:TableCell > 
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<asp:TableCell ID -"TableCell6" runat -'server" > 
<% Convert. ToDateTime (DataBinder. Eval (Container. DataItem," Æ H ")). 
ToShortDateString () $ > 
«/asp:TableCell > 
«asp:TableCell ID -"TableCell7" runat -'server" > 
«S$3pataBinder.Eval (Container.DataItem, "电话 ")%> 
«/asp:TableCell > 
«asp:TableCell ID -"TableCell8" runat -'server" > 
«asp:Button ID -"Buttonl" runat -"server" Text 二 编辑 " 
ConmandNare -"Edit"/ > 
«/asp:TableCell > 
«/asp:TableRow > 
«/asp:Table > 
«/IteniTemplate > 
XEditItemTemplate > 
«asp:Table ID -"Table3" runat -"server" Width -"500" GridLines oth > 
Xasp:TableRow ID -"TableRow3" runat -"server" HorizontalAlign -"Center" > 
Xasp:TableCell ID -"TableCell9" runat -"server" > 
<asp:TextBox runat -"Server" ID -"name" Width ="90" 
Text -' &BataBinder.Eval (Container.DataItem, "IE ")2 »' /> 
«/asp:TableCell > 
Xasp:TableCell ID -"TableCelll0" runat -"server" > 
<asp:TextBox runat -"server" ID -"Birthday" Width ="90" 
Text -' «&£onvert . ToDateTime (DataBinder.Eval (Container .DataItem, 
"E H ")) .ToShortDateString() $ »' /> 
«/asp:TableCell» 
«asp:TableCell ID -"TableCellll" runat -"server" > 
<asp:TextBox runat -"server" ID -"Tel" Width ="130" 
Text =' &BataBinder.Eval (Container.DataItem, "电话 ") 当 >' /> 
«/asp:TableCell» 
Xasp:TableCell ID -"TableCelll2" runat -"server" > 
«asp:LinkButton ID -"LinkButtonl" runat -"server" Width -"18" 
Text = 更 新 " ConmandName -"Update" / > 
«asp:LinkButton ID -"LinkButton2" runat -"server" Width ="18" 
Text = 删除 "CommandName "Delete" / > 
<asp:LinkButton ID -"LinkButton3" runat -"server" Width -"18" 
Text = 取消 " CommandName -"Cancel" / > 
</asp:TableCell > 
</asp:TableRow > 
</asp:Table > 
</EditItemTemplate > 
<HeaderStyle HorizontalAlign -"Center" BackColor ="#66CCFF" ForeColor -"Red" /> 
XItemStyle BackColor -"Moccasin" / > 
«EditItemStyle BackColor -"Lavender" /> 
</asp:DataList > 
</fom> 
(2) DataList. aspx. cs 文件 的 程序 代码 如 下 : 
OleDbDataAdapter adapter; 


DataSet DS; 


protected void Page Load (object sender,EventArgs e) 


í 


下 


String str -"Provider -Microsoft.Jet.OLEDB.4.0;Data Source =" + 
Server.MapPath ("../App Data/factory.mdb"); 

OleDbConnection con -new OleDbConnection (str) ; 

adapter -new OleDbDataAdapter ("select + from 通讯 德 ",con) ; 

DS -new DataSet () ; 

adapter .Fill(DS, "Bi IRE") ; 

myDataList.DataSource 30S; 

if (!Page.IsPostBack) myDataList.DataBind|(); 


// 进 入 数据 编辑 模式 
protected void Edit (Object sender, DataListCommandEventArgs e) 


myDataList.EditItemIndex -e.Item.ItemIndex; 
myDataList.DataBind(); 


// 退 出 数据 编辑 模式 
protected void Cancel (Object sender, DataListCommandEventArgs e) 


myDataList.EditItemIndex =-1; 
myDataList.DataBind(); 


// 删 除数 据 
protected void Delete (Object sender, DataListCommandEventArgs e) 


DS.Tables ("il ifl "] .Rows [e. Item. ItemIndex] .Delete () ; 

// 创 建 命令 生成 对 象 ,以 便 获得 adapter 的 DeleteConmand 属性 的 值 
OleDbConmandBuilder builder new OleDbCommandBuilder (adapter) ; 
adapter .DeleteCommand -builder.GetDeleteCommand () ; 

// 用 数据 集 对 象 的 student 表 去 更 新 适配器 对 象 指定 的 数据 表 
adapter.Update (DS, "illi TUE") ; 

DS.Clear(); 

adapter .Fill(DS, "il TRE") ; 

myDataList.EditItemIndex =-1; 

myDataList.DataSource -DS; 

myDataList.DataBind(); 


// 更 新 数据 
protected void Update (Object sender, DataListCommandEventArgs e) 


{ 


int row =e. Item. ItemIndex; 
DS.Tables[" 通 讯 秒 "] .Rows [row] [" 姓 名 "] = 
((TextBox) e. Item.FindControl ("name")) .Text; 
DS.Tables ["i IRE" ] -Rows [row] [" 生 日 "] = 
((TextBox) e. Item.FindControl ("Birthday")) .Text; 
DS.Tables [3B TRE "] -Rows [row] [" 电 话 "] = 
( (TextBox)e. Item.FindControl ("Tel")) .Text; 
OleDbCormmandBui lder builder new OleDbConmandBui lder (adapter) ; 
adapter .UpdateCommand -bui lder . GetUpdateConmand () ; 
// 用 数据 集 的 指定 表 去 更 新 适配器 对 象 的 数据 表 
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adapter .Update (DS, "通讯 簿 ") ; 
DS.Clear(); // 清 除 Ds 中 所 有 数据 表 中 的 记录 ,使 数据 表 成 为 空 表 
adapter .Fill(DS, "il Ri") ; 
myDatalist.EditItemIndex —-1; 
myDataList.DataSource DS; 
myDataList.DataBind(); 
) 


在 DataGrid 控件 中 ,每 一 个 数据 行 都 是 DataGridltem 对 象 ,存在 Cells 集合 , 见 例 6-7 中 
的 程序 代码 。 在 DataList 控件 中 ,每 一 个 数据 行 都 是 DataListItem 对 象 ,不 存在 Cells 集合 。 


6.3 Repeater 控件 


与 DataGrid 控件 和 DataList 控件 相 比 , Repeater 控件 简单 小巧、 使 用 灵活 ,但 功能 比 
DataGrid 或 DataList 控件 减弱 很 多 。 它 只 能 应 用 模板 将 数据 表 中 的 数据 显示 出 来 ,不 能 对 记 
录 进 行 删除 ,更 新 等 操作 。 

Repeater 控件 支持 5 种 模板 。 

(1) HeaderTemplate ; 页 眉 模板 ,用 来 定义 Repeater 控件 的 标题 。 

(2) ItemTemplate; 数据 模板 ,用 来 定义 每 个 数据 行 要 显示 的 数据 ,此 模板 不 能 
省 略 。 

(3) AlternatingItemTemplate: 隔行 数据 模板 ,用 来 定义 隔行 显示 的 数据 。 如 果 设置 了 此 
模板 , 则 奇数 行 数据 会 应 用 数据 模板 ,偶数 行 数据 应 用 隔行 数据 模板 。 

(4) SeparatorTemplate: 分 隔 模板 ,定义 两 行 数据 之 间 如 何 分 隔 。 

(5) FooterTemplate; 页 脚 模板 。 

【 例 6-10】 在 站 点 中 添加 一 个 名 称 为 Repeaterl. aspx 的 网 页 ,使 用 Repeater 控件 来 显 
示 student 表 中 的 记录 ,要 求 在 符号 分 隔 的 列表 中 显示 。 

(1) 用 户 界面 的 代码 如 下 : 


<form id ="forml" runat ="server" > 
<asp:Repeater runat ="Server" ID -"myRepeater" > 
<HeaderTemplate > 
<hl 六 印 机 报价 单 /hl > 


</HeaderTemplate > 

<ItemTemplate > 
学 号 : &pataBinder .Eval (Container.DataItem, "sno") 当 ><br > 
姓名 : <% 和 ataBinder.Eval (Container.DataItem, "sname") 当 ><br > 
性 别 : «SataBinder.Eval (Container.DataItem, "ssex")$ ><br > 
年 龄 : «$BataBinder.Eval (Container.DataItem, "sage")$»4br» 
系 别 : «BataBinder.Eval (Container.DataItem, "sdept")$ ><br > 

«/ItentTemplate > 

«AlternatingltenTemplate > 
«font color ="#F0000" > 
学 号 : &pataBinder.Eval (Container .DataItem, "sno")£ »«br > 
姓名 : «pataBinder.Eval (Container.DataTtem, "sname")$ » «br > 
性 别 : «BataBinder.Eval (Container.DataTtem, "ssex")$ ><br > 
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年 龄 : pataBinder.Eval (Container .DataItem, "sage")$ ><br > 
系 别 : <sjpataBinder.Eval (Container.DataItem, "sdept")? ><br > 
</font > 
«/AlternatingItenTemplate > 
<SeparatorTemplate > 
«Hr Width -"200" Align -"Ieft" > 
«/SeparatorTemplate > 
«FooterTemplate > 
qr 至 此 结束 --------- 
X/FooterTemplate > 
</asp:Repeater > 
</fom> 


(2) Repeaterl. aspx. cs 文件 的 程序 代码 如 下 : 


protected void Page Load (object sender, EventArgs e) 
{ 
String str ="server -localhost;uid =sa;pwd =; database =stu"; 
SqlConnection con new SqlConnection (str); 
DataSet DS -new DataSet () ; 
SqlDataAdapter adapter -new SqlDataAdapter ("select * from student",con); 
adapter.Fill(DS, student"); 
myRepeater . DataSource =DS; 
myRepeater .DataBind () ; 
} 


[616-11] 在 站 点 中 添加 一 个 名 为 Repeater2. aspx 的 网 页 ,使 用 Repeater 控件 来 显示 
student 表 中 的 记录 ,要 求 以 表格 形式 显示 记录 。 
用 户 界面 的 代码 如 下 : 


<form id ="forml" runat -"server" > 

«center > 

Xasp:Repeater ID ="Repeater1" runat -"server" > 
XHeaderTenplate > 

«table width ="300" border ="1" cellspacing ="0" > 

«r» 

«td style "height: 30px" X5 </td> 

<td > 姓名 «tà» 

<td HEJ </td> 

<td :年龄 wtda> 

<td> J] </td> 

</tr> 

«/HeaderTemplate > 

XItenTemplate > 

«Xr» 

«td style "height: 30px" > «$BataBinder.Eval (Container.Dataltem, "sno")$ ></td > 
«td > &BataBinder.Eval (Container.Dataltem, "sname")$ ></td > 
«td > «&fataBinder.Eval (Container .DataItem, "ssex")£ ></td> 
«td > «&BataBinder.Eval (Container.Dataltem, sage") $ » «/td > 
«td » «$BataBinder.Eval (Container.Dataltem, "sdept")$ »«/td > 
«tr» 
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</ItemTemplate > 

«AlternatingItenTemplate > 

<tr> 

«td style -"color:red; font -family: 华 文中 宋 ;height:30px;"> 
«S&pataBinder.Eval (Container .Dataltem, "sno") 当 ></td > 

«td style -"color:red;font -family: 华 文中 宋 " > 
«&pataBinder.Eval (Container.DataItem, "sname") 当 ></td > 

«td style "color:red; font -family: 华 文中 宋 " > 
«S9ataBinder.Eval (Container.Dataltem, "ssex")$ »«/td > 

«td style -"color:red; font -family: 华 文中 宋 " > 
«SpataBinder.Eval (Container .DataItem, "sage")% ></td > 

«td style -"color:red; font -family: 华 文中 宋 "> 
«SpataBinder.Eval (Container .DataItem, "sdept")$ ></td > 

</tr> 

</AlternatingItemTenplate > 

«FooterTemplate > 

</table> 

</FooterTemplate > 

</asp:Repeater > 

</center > 

</fom> 


6.4 简单 服务 器 控件 的 数据 绑 定 


前 面 几 节 介 绍 了 DataGrid , DataList 和 Repeater 控件 ,这 几 个 控件 的 用 法 都 比较 复杂 , 称 
为 复杂 绑 定 控件 。 其 他 的 服务 器 控件 也 支持 数据 绑 定 ,都 有 DataBind( ) 方 法 ,统称 为 简单 
绑 定 控件 ,如 Label 控件 TextBox 控件 DropDownList 控件 和 ListBox 控件 。 

在 使 用 这 些 控件 进行 数据 绑 定 .显示 数据 时 ,一 般 要 经 过 如 下 3 个 步骤 。 

(1) 准备 好 数据 源 , 这 些 数据 可 能 是 变量 .表达 式 .方法 的 返回 值 .数组 ,集合 .DataView 
对 象 和 DataReader 对 象 等 。 

(2) 为 服务 器 控件 设置 数据 源 。 数 据 源 的 设置 方法 有 两 种 。 

GD 对 于 没有 DataSource 属性 的 控件 ,可 以 直接 把 数据 源 的 数据 指定 给 控件 的 某 个 属 
性 ,格式 为 : 属性 名 =" coo idee». 

@ 对 于 有 DataSource 属性 的 控件 ,可 以 直接 把 数据 源 的 数据 指定 给 控件 的 DataSource 
属性 。 

(3) 将 数据 源 绑 定 到 服务 器 控件 中 。 绑 定数 据 源 的 方法 有 两 种 。 

CD 调用 服务 器 控件 自身 的 DataBind( ) 方 法 。 

© 调用 Page 对 象 的 DataBind( ) 方 法 。 在 调用 Page 对 象 的 DataBind( ) 方 法 时 ,Page 对 
象 会 自动 调用 本 页 所 有 控件 的 DataBind( ) 方 法 。 


1. 简单 变量 做 数据 源 

【 例 6-12】 在 站 点 中 添加 一 个 名 称 为 examplel. aspx 的 网 页 ,使 用 数据 绑 定 技术 ,使 
Label 控件 和 Button 控件 的 文本 显示 两 个 字符 变量 sl 和 s2 的 值 。 运 行 结果 如 图 6-5 所 示 。 

(1) 创建 examplel. aspx 网 页 ,在 其 中 添加 Label 控件 和 Button 控件 。 
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(2) 在 网 页 后 台 的 隐藏 代码 中 ,添加 成 员 变量 s1 .s2 ,代码 
如 下 : 


public String s1 -"Hello"; 
public String s2 -"World!"; 


果 (3) 切换 到 页 面 HTML 视图 ,设置 Labell 控件 和 Buttonl 控 
件 的 绑 定 表达 式 , 代 码 如 下 : 


<asp:Label ID-"Labell" runat -"server" Text =" < %#1%>"></asp:Label > 
<asp:Button ID = "Button1" runat -"server" Text =" %2% >"/ > 


(4) 在 网 页 后 台 的 隐藏 代码 中 ,给 Page: Load ( ) 方 法 添加 下 列 代码 ; 


ET 


E 
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Page.DataBind(); 


2. 表达 式 和 方法 返回 值 做 数据 源 

【 例 6-13】 在 站 点 中 添加 一 个 名 为 example2. aspx 的 网 页 ,假设 张 三 同 学 的 语文 数 
学 英语 成 绩 已 知 , 且 分 别 放 在 3 个 变量 中 ,要 求 显示 总 分 站 
及 是 否 及 格 。 运 行 结果 如 图 6-6 所 示 。 i EO ép SEV ua? AY 

(1) 创建 example2. aspx 网 页 ,在 其 中 添加 Label fi 
件 和 CheckBox 控件 。 

(2) 在 网 页 后 台 的 隐藏 代码 中 ,添加 存放 3 门 课 成 绩 |‖ te 
的 成 员 变量 chi mat eng, 代码 如 下 ; LO 

protected float chi -90; 


protected float mat -59; 
protected float eng -93; 


(3) 编写 判断 是 否 有 不 及 格 科目 的 方法 GetPassOrNot( ) ,代码 如 下 : 


protected bool GetPassOrNot () 
í 


张 三 的 总 分 


[s] 


图 6-6 (56-13 运行 结果 


return (chi >=60 && mat »-60 && eng >60) ? false:true; 
) 


(4) 切换 到 页 面 HTML 视图 ,设置 Labell 控件 和 CheckBoxl 控件 的 绑 定 表 达 式 ,代码 如 


<asp:Label id -"Labell" runat -"server" Text =" <%#hi mat +eng% >" ></asp:Label > 
Xasp:CheckBox id -"CheckBoxl" runat -"server" Checked =" < $fetPassOrNot () $ >"/> 


(5) 在 网 页 后 台 的 隐藏 代码 中 ,给 Page. Load ( ) 方 法 添加 下 列 代码 : 


Page.DataBind(); 


3. 数组 做 数据 源 

【 例 6-14】 在 站 点 中 添加 一 个 名 称 为 example3. aspx 的 网 页 ,已 知 各 个 城市 名 已 存储 
在 一 个 字符 串 数组 中 ,加 载 页 面 后 ,要 求 在 下 拉 列 表 框 中 显示 各 城市 名 。 运 行 结果 如 图 6-7 
所 示 。 
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(1) 创建 example3. aspx 网 页 ,在 其 中 添加 一 个 DropDownList 4 


控件 。 
(2) 在 网 页 后 台 的 隐藏 代 码 中 ,添加 成 员 变 量 s, 代 码 如 下 : 

protected String[]s ={ "J^ JH ", "深圳", "珠海 "," 汕 头 "," 佛 山 "， 

"EUN; 

(3) 切换 到 页 面 HTML 视图 ,设置 DropDownListl 控件 的 绑 定 
表达 式 ,代码 如 下 : 

图 6-7 例 6-14 运行 结果 
< asp: DropDownList id -" DropDownListl" runat -" server" 


DataSource =" G&$ %>" > 
</asp:DropDownList > 


(4) 在 网 页 后 台 的 隐藏 代码 中 ,给 Page_Load( ) 方 法 添加 下 列 代码 : 


DropDownList1 .DataBind () ; 


65 项 目 实 训 


实 训 1 数据 绑 定 的 应 用 


实 训 目的 

(1) 了 解数 据 绑 定 的 基本 原理 。 

(2) 掌握 简单 Web 控件 的 数据 绑 定 方法 。 

(3) 掌握 不 同 种 类 数据 源 的 数据 绑 定 方法 。 

实 训 要 求 

(1) 创建 一 个 Web 网 站 sx06 ,并 设置 成 虚拟 目录 。 

(2) 在 网 站 中 添加 一 个 名 称 为 sx6_1. aspx 的 网 页 ,实现 简单 的 投票 统计 和 显示 功能 。 


初始 界面 和 运行 界面 如 图 6-8 、 图 6-9 所 示 。 


| iei EREN, zs | nek | wx 
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图 6-8 实 训 1 初始 界面 
实 训 提示 
(1) 在 第 2 列 单元 格 内 添加 Image 控件 ,图 片 源 为 3 种 不 同 颜 色 的 图 片 : red. jpg, 


yellow. jpg blue. jpg。 
(2) 在 网 页 后 台 的 隐藏 代码 中 添加 3 个 成 员 变量 v1 v2、v3, 用 于 存放 投票 数 ,代码 


WP: 


protected static int v1,v2,v3; 


第 6 章 数据 控件 155 
= “和 < 
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图 6.9 实 训 1 运行 界面 
(3) 切换 到 页 面 HTML 视图 ,设置 第 2 列 Image 控件 的 绑 定 表达 式 , 代 码 如 下 ; 


<asp:Image ID-"Imagel" runat-"server" Width =" «$$ + v1% >" Height -"25px" ImageUrl = 
" ^/5x06/image/red. jpg"/ > 

Kasp:lmage ID-"Image2" runat-"server" Width =" & * v2$ ^" Height -"25px" ImageUrl = 
" ^/sx06/image/yellow.jpg"/ > 

<asp:Image ID-"Image3" runat="server" Width =" «$$ * v3%>" Height — "25px" ImageUrl 

= ^/sx06/image/blue.jpg"/ > 


(4) 设置 第 3 列 显示 票数 的 Label 控件 的 绑 定 表达 式 ,代码 如 下 : 


<asp:Label ID -"Labell" runat -"server" Text =" «&&1$ >" » «/asp:Label > 
<asp:Label ID -"Label2" runat -"server" Text =" «$425 >" ></asp:Label > 
<asp:Label ID 7"Label3" runat -"server" Text =" «$43$ >" » «/asp:Label > 


(5) 设置 第 4 列 显 示 票 数 百 分 比 的 Label 控件 的 绑 定 表达 式 为 cal( ) 的 返回 值 ,代码 
如 下 : 


<asp:Label ID="Label4" runat -"server" Text =" <%#al (v1) $ >" ></asp:Label > 
<asp:Label ID="Label5" runat -"server" Text =" <%#al (v2) $ >" ></asp:Label > 
<asp:Label ID="Label6" runat -"server" Text =" <%#al (v3) $ >" ></asp:Label > 


(6) 在 网 页 后 台 的 隐藏 代码 中 添加 计算 票数 百分比 的 方法 cal( ) ,代码 如 下 : 


protected String cal (int i) 
{ 
int s =v1 2 +3; 
String r; 
if (s--0) r ="0%"; 
else 
r-(Convert.ToDecimal(i)/s * 100) .ToString ("n2") +"%"; 
return r; 


} 
(7) 添加 第 5 列 “ 投 票 "按钮 的 共同 的 事件 处 理 方法 ,代码 如 下 : 


protected void Buttonl Click (object sender, EventArgs e) 
{ 
if(((Button)sender).ID--"Buttonl") vl ++; 
else if(((Button)sender) .ID--"Button2") v2 ++; 
else v3 ++; 
this.DataBind(); 
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(8) 给 Page_Load( ) 方 法 添加 代码 : 


DropDownListl.DataBind(); 


实 训 2 DataGrid 控件 的 应 用 

实 训 目 的 

(1) 掌握 DataGrid 控件 的 “手动 指定 列 "模式 。 

(2) 掌握 DataGrid 控件 分 页 显示 数据 表 中 记录 的 方法 。 

(3) 掌握 用 DataGrid 控件 修改 、 删 除数 据 表 中 记录 的 方法 。 

实 训 要 求 

(1) 在 网 站 中 添加 一 个 名 称 为 sx6_2. aspx 的 网 页 ,利用 DataGrid 控件 的 模板 列 将 “ 素 
材 A” 数 据 库 中 “职工 " 表 中 的 数据 以 表格 的 形式 显示 出 来 。 

(2) DataGrid 控件 支持 分 页 显示 ,每 页 显示 15 条 记录 ,分 页 块 显示 数字 页 码 , 单 击 某 一 
个 页 码 , 就 能 显示 相应 页 的 全 部 记录 。 

(3) 单 击 某 一 行 的 “编辑 "按钮 时 ,该 行 就 进入 编辑 模式 ,如 图 6-10 所 示 。 


Fh 
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图 6-10 编辑 模式 


(4) 在 编辑 模板 中 加 入 相应 的 验证 控件 ,以 便 在 单 击 “ 更 新 "按钮 时 能 对 各 字段 值 进 行 
控制 ,不 更 新 “职工 号 ”。 

(5) 单 击 “ 删 除 ”按钮 ,能 删除 该 记录 。 单 击 * 取 消 "按钮 ,能 使 该 记录 进入 显示 模式 。 
单 击 “ 删 除 "“ 取 消 "按钮 时 ,不 要 调用 验证 控件 。 

实 训 提 示 

(1) 为 编辑 模板 加 入 验证 控件 时 ,要 求 将 验证 控件 Display 属性 设置 为 " none" ,在 
DataGrid 控件 的 最 后 一 列 的 编辑 模板 中 加 入 ValidationSummary 控件 ,将 出 错 信 息 以 对 话 框 
形式 进行 汇总 显示 ,代码 如 下 : 

<asp:ValidationSurmary ID -"ValidationSummaryl"runat -"server" 

ShowMessageBox ="true" ShowSunmary ="false"/ > 

(2) 在 “删除 " “取消 ?按钮 的 代码 中 加 入 CausesValidation =" false" 语句, 可 使 两 个 按 
钮 不 调用 验证 控件 。 


实 训 3 DataList 控件 的 应 用 


实 训 目 的 

(1) 掌握 DataList 控件 显示 数据 表 中 记录 的 方法 。 

(2) 掌握 用 DataList 控件 修改 ,删除 数据 表 中 记录 的 方法 。 

实 训 要 求 

在 站 点 中 添加 一 个 名 称 为 sx6_3. aspx 的 网 页 ,利用 DataList 控件 实现 对 “素材 A" 数 据 
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库 中 ”书籍 管理 " 表 中 数据 进行 修改 ,删除 等 操作 ,运行 界面 如 图 6-11 所 示 。 


图 6-11 实 训 3 运行 界面 


思考 与 练习 
一 、 填 空 题 
1. DataGrid 控件 用 于 将 数据 表 中 的 数据 以 形式 显示 出 来 ,同时 支持 
,更 新 记录 等 操作 。 


2. 在 调用 Page 对 象 的 DataBind( ) 方 法 时 ,Page 对 象 。 
3. 单 击 DataGrid 控件 中 某 一 行 CommandName 为 Edit 的 按钮 时 ,该 行 就 进入 


模式 ,所 有 的 列 都 可 以 编辑 ， 列 在 指定 编辑 数据 模板 时 也 可 以 编辑 ,但 其 
他 类 型 的 列 不 能 编辑 。 

4. 单 击 DataGrid 控件 内 的 任何 一 个 按钮 都 会 触发 事件 。 

二 、 简 答题 


1. 简 述 DataGrid 控件 如 何 实现 数据 的 分 页 显示 。 
2. DataList 控件 能 支持 哪些 模板 ? 
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.NET Framework 的 System. IO 命名 空间 提供 了 许多 类 ,用 来 访问 服务 器 端的 文件 
和 文件 夹 ,允许 对 文件 夹 进行 创建 ,删除 和 查看 操作 ,对 文件 进行 创建 .删除 . 读 取 和 写 
人 操作 。 


。 掌握 服务 器 端 文件 夹 的 创建 ,删除 和 查看 方法 
。 掌握 服务 器 端 文件 的 创建 .删除 方法 

。 掌握 读 写 服务 器 端 文件 的 方法 

。 掌握 上 传 文件 的 方法 


7.1 概 述 


由 于 System. 10 不 是 预定 义 的 命名 空间 ,在 使 用 System. 10 命名 空间 的 类 之 前 ,必须 先 
导入 System. IO 命名 空间 ,代码 为 : 


using System. IO; 
System. IO 命名 空间 提供 的 类 如 表 7-1 所 示 。 
表 7-1 System.IO 命名 空间 提供 的 类 


类 说 明 
Directory 用 来 创建 移动 .删除 文件 夹 , 并 能 列 出 文件 夹 中 包含 的 内 容 
File 用 来 创建 ,打开 文本 文件 ,复制 移动 或 删除 任意 文件 
StreamReader 字符 流 类 ,用 来 读 取 文本 文件 中 的 内 容 
StreamWriter 字符 流 类 ,用 来 向 文本 文件 中 写 人 文本 
FileStream 字 节 流 类 ,用 来 对 任意 类 型 的 文件 进行 读 写 操作 


注意 : System. 10 命名 空间 提供 的 类 用 来 访问 服务 器 端的 文件 或 文件 夹 ,文件 或 文件 夹 
必须 使 用 绝对 路 径 , 且 分 隔 符 必须 为 /, 例 如 ,在 C# 语 名 中 使 用 “DD:/TT/Talking”。 
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7.2 Directory 类 


Directory 类 的 常用 方法 如 表 7-2 Bros ,这些 方 法 均 是 静态 的 。 
表 7-2 Directory 类 的 常用 方法 


方 法 说 "9 
CreateDirectory 创建 指定 的 文件 夹 
GetDirectories 列 出 文件 夹 内 所 有 子 文件 夹 的 路 径 
GetFiles 列 出 文件 夹 内 所 有 文件 的 路 径 
GetFileSystemEntries 列 出 文件 夹 内 所 有 文件 及 子 文件 夹 的 路 径 
Delete 删除 文件 夹 
Move 移动 文件 夹 和 文件 
Exists 判断 文件 夹 是 否 存在 
GetCreationTime 获取 文件 夹 或 文件 的 创建 日 期 和 时 间 
GetLastAccessTime 获取 文件 夹 或 文件 最 后 一 次 被 访问 的 日 期 和 时 间 
1. 创建 文件 夹 
格式 如 下 : 


Directory.CreateDirectory (Path); 

功能 : 创建 指定 的 文件 夹 , 若 路 径 中 的 其 他 文件 夹 也 不 存在 , 则 会 一 并 创建 。 若 指定 的 
文件 夹 已 存在 , 则 忽略 此 方法 。 

例如 ,创建 文件 夹 D;\TT\Talking, 代 码 如 下 :; 


Directory.CreateDirectory ("D: /TT/Talking") ; 


2. 列 出 文件 来 中 的 文件 或 子 文件 来 

(1) String[ ] 数 组 名 = Directory. GetDirectories( path , 通 配 串 ) 。 

将 指定 文件 夹 内 所 有 子 文件 夹 的 路 径 存 人 字符 串 数 组 中 。 通 配 串 是 指 包括 通配符 
“* "或 “9 "的 字符 串 , 若 省 略 不 写 , 则 默认 为 " * "。 其 中 ,“* "用 来 替代 一 申 字 符 ,“?" 用 来 
替代 一 个 字符 。 例 如 ,将 D:\TT\Talking 内 所 有 以 “w" 开 头 的 子 文件 夹 的 路 径 存 人 字符 串 数 
组 a 中 ,代码 如 下 : 


String[]a -Directory.GetDirectories ("D: /TT/Talking", "w* "); 


(2) String[ ] 数 组 名 = Directory. GetFiles( path , 通 配 串 ) 。 

功能 : 将 指定 文件 夹 内 所 有 文件 的 路 径 存 入 字符 串 数组 中 。 

(3) String[ ] 数 组 名 = Directory. GetFileSystemEntries( path , 通 配 串 ) 。 
功能 : 将 指定 文件 夹 内 所 有 子 文件 夹 及 文件 的 路 径 存 人 字符 串 数 组 中 。 


3. 删除 文件 夹 
格式 如 下 : 
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Directory.Delete (path[,mode]) 
参数 mode 用 来 指定 是 否 删除 子 文 件 夹 及 文件 , 若 mode = true, 则 可 以 删除 非 空 文件 夹 ; 


若 mode = false, 则 只 能 删除 空 文件 夹 ,默认 为 false。 若 指定 的 文件 夹 不 存在 , 则 发 生 异常 错 
误 。 例 如 ,删除 D: VTT 下 的 Talking 文件 夹 ,Talking 非 空 , 则 代码 如 下 ; 


Directory.Delete ("D:/TT/Talking" ,true); 


4. 移动 文件 夹 和 文件 

格式 如 下 : 

Directory.Move ( 原 路 径 , 新 路 径 ) 

功能 : 将 文件 或 文件 夹 从 当前 位 置 移动 到 目标 位 置 ,移动 后 的 文件 名 或 文件 夹 名 可 以 
与 源 文件 或 源 文件 夹 不 同 。 

例如 ,将 D:VTT 下 的 Talking 文件 夹 移动 到 D:\ 下 ,移动 后 的 文件 夹 名 称 不 变 , 则 代码 如 
F: 

Directory.Move ("D:/TT/Talking","D:/Talking"); 

XAN Ki D; \TT 下 的 Talking 文件 夹 移动 到 D:\ 下 ,移动 后 的 文件 夹 名 称 为 speaking, 则 
代码 如 下 : 

Directory.Move ("D: /TT/Talking", "D: /speaking") ; 

再 如 ,将 D:VTT 下 的 1. va 文件 移动 到 D:\ 下 , 则 代码 如 下 : 

Directory.Move ("D: /TT/1 . txt", "D: /1.txt") ; 

注意 : 使 用 Directory 类 的 Move 方法 只 能 在 一 个 逻辑 盘 内 移动 文件 或 文件 夹 。 

5. 判断 文件 夹 是 否 存在 

Directory.Exists (path) 

判断 path 指定 的 文件 夹 是 否 存在 ,返回 值 为 rue 或 false。 

6. 其 他 

(1) Directory. GetCreationTime( path ) : 获取 path 指定 的 文件 夹 或 文件 的 创建 日 期 和 时 
间 , 返 回 DateTime 类 型 值 。 

(2) Directory. CetLastAccessTime( path ) : 获取 path 指定 的 文件 夹 或 文件 最 后 一 次 被 访 
问 的 日 期 和 时 间 ,返回 DateTime 类 型 值 。 

【 例 7-1】 在 站 点 的 Directory 目录 下 添加 一 个 名 称 为 pem T 
Directory. aspx 的 网 页 ,判断 C: \Inetpub \wwwroot \ Talking 文件 HD SED SED? Q 
夹 是 否 存在 ,如 果 不 存 在 ,就 创建 该 文件 夹 ,并 获取 文件 夹 的 mxomom aona E 
相关 信息 。 运 行 界面 如 图 7-1 所 示 。 ings et 

主要 程序 代码 如 下 : 


protected void Page Load (object sender, EventArgs e) 


图 7-1 例 7-1 运行 界面 
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String dirPath -"C: /Inetpub/wwwroot/Talking"; 
if (Directory.Exists (dirPath) ==false)  Directory.CreateDirectory (dirPath); 
Response.Write ( "文件 夹 创建 时 间 :" 3Directory.GetCreationTime (dirPath) +" «br >"); 
Response.Write ("文件 夹 最 后 访问 日 期 :" 4Directory.GetLastAccessTime (dirPath) . 
ToShortDateString () +" «br >"); 
Response.Write ("文件 夹 的 根 目录 : " 4Di rectory.GetDirectoryRoot (dirPath) +" «br >") ; 
) 
[917-2] 在 站 点 的 Directory 目录 下 添加 一 个 名 称 为 Entries. aspx 的 网 页 ,用 于 列 出 
Directory 目录 下 的 所 有 文件 及 子 文件 夹 。 
主要 程序 代码 如 下 : 
protected void Page Load (object sender, EventArgs e) 
{ 
String[]a -Directory.GetFileSystemEntries (Server.MapPath (" ../Di rectory") , " * ") ; 


foreach (String x in a) 
{ Response.Write (x+" «br >") ; } 


7.3 File 类 


File 类 的 常用 方法 如 表 7-3 所 示 ,这些 方 法 均 是 静态 的 。 
X73 File 类 的 常用 方法 


Ù 法 o" 
Create. 创建 指定 的 文本 文件 ,返回 FileStream 对 象 
CreateText 创建 指定 的 文本 文件 ,返回 StreamWriter 对 象 
Open 打开 指定 的 文本 文件 ,返回 FileStream 对 象 
OpenText 打开 指定 的 文本 文件 ,返回 StreamWriter 对 象 
Move 将 文件 从 当前 位 置 移 动 到 目标 位 置 
Copy 将 文件 从 当前 位 置 复制 到 目标 位 置 
Delete 删除 指定 的 文件 
Exists 判断 指定 的 文件 是 否 存在 

1. 创建 文本 文件 


FileStream 对 象 名 -File.Create (path) ; 
StreanWriter 对 象 名 -File.CreateText (path) ; 


功能 : 创建 path 指定 的 文本 文件 , 若 指定 的 文件 已 经 存在 , 则 将 其 覆盖 。 

FileStream 为 字 节 流 类 ,在 字 节 流 类 中 ,每 个 英文 字母 数字 占 1 个 字 节 ,每 个 汉字 占 
2 个 字 节 。 默 认 字符 编码 方式 为 System. Text. Encoding. Default, StreamWriter 为 字符 流 类 ， 
在 字符 流 类 中 ,每 个 英文 字母 数字、 汉字 占 2 个 字 节 。 默 认 字符 编码 方式 为 System. Text. 
Encoding. UTF8 ( 即 包含 全 世界 的 文本 和 字符 ) 。 


2. 打开 文件 
(1) FileStream 对 象 名 = File. Open( path,mode [ ,access] ) ; 
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功能 : 打开 path 指定 的 文本 文件 ,并 返回 FileStream 对 象 。 

O 参数 mode 为 文件 的 打开 模式 ,可 以 取 以 下 两 个 值 。 

* FileMode. Open; 打开 文件 ,车 文件 不 存在 , 则 产生 异常 错误 ; 

* FileMode. OpenOrCreate; 打开 文件 , 若 文件 不 存在 , 则 创建 文件 。 

@ 参数 access 用 来 指定 文件 的 访问 类 型 ,可 以 取 以 下 3 个 值 。 

* FileAccess. Read; 文件 只 可 读 取 ; 

* FileAccess. Write; 文件 只 可 写 和 人 ; 

e FileAccess. ReadWrite; 文件 可 以 读 取 及 写 入 ,此 为 默认 值 。 

例如 ,打开 D:VMT 下 的 1.txt 文件 ,使 文件 可 供 读 取 和 写 和 人 , 则 代码 如 下 : 


FileStream fs -File.Open ("D: /TT/1 .txt", FileMode.Open, FileAccess.ReadWrite) ; 


(2) StreamReader 对 象 名 = File. OpenText( path ) ; 
功能 : 以 只 读 方式 打开 path 指定 的 文本 文件 ,并 返回 StreamReader 对 象 。 
fin : 


StreamReader sr -File.OpenText ("D: /TT/1.txt"); 


3. 移动 文件 
File.Move ( 原 路 径 , 新 路 径 ) 


功能 : 将 文件 从 当前 位 置 移 动 到 目标 位 置 ,移动 后 的 文件 名 可 以 与 源 文件 不 同 。 
例如 ,将 D:\TT 下 的 1.txt 文 件 移动 到 C:\ 下 ,移动 后 的 文件 名 不 变 , 则 代码 如 下 : 


File.Move ("D: /TT/1.txt","C:/1.txt"); 

注意 : Directory 类 的 Move Zr f E3539 5E fc 2), 49. File 类 的 Move 方法 可 以 。 
4. 复制 文件 

File.Copy( 原 路 径 ,新 路 径 [,overwrite]) 


功能 : 复制 当前 位 置 的 文件 到 目标 位 置 , 复 制 后 的 文件 名 可 以 与 源 文件 名 不 同 。 
参数 overwrite 用 来 指定 当 目标 文件 已 存在 时 是 否 履 盖 它 ,默认 为 false。 
例如 ,将 D:\TT 下 的 1.txt 文 件 移动 到 C:\ 下 ,复制 后 的 文件 名 为 newl. txt, 如 果 目 标 文 


件 已 经 存在 ,那么 会 覆盖 原来 的 文件 ,代码 如 下 : 


File.Copy ("D: /TT/1 .txt","C:/newl .txt", true) ; 


5. 删除 文件 

File.Delete (path) 

功能 : 删除 path 指定 的 文件 , 若 指定 的 文件 不 存在 , 则 忽略 此 方法 。 
6. 判断 文件 是 否 存在 


File.Exists (path) 
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功能 : 判断 path 指定 的 文件 是 否 存在 ,返回 值 为 rue 或 false, 
【 例 7-3】 在 站 点 的 File 目录 下 添加 一 个 名 称 为 File. aspx 的 


网 页 设计 蛋 面 如 图 所 文件 的 基本 操作 

l,i 面 如 图 7-2 所 示 。 - 

OR aaa 
(1) 单 击 “ 创 建 "按钮 ,就 在 File 目录 下 创建 byte. txt 5j char. 

txt 文 件 。 图 72 例 73 设 计 界面 


(2) 单 击 “ 复 制 " 按 钮 ,就 将 char. txt 文件 复制 到 站 点 根 目录 下 。 

(3) 单 击 “ 移 动 "按钮 ,就 将 byte. xt 文件 移动 到 站 点 根 目录 下 。 

(4) 单 击 “ 删 除 ”按钮 ,就 将 站 点 根 目 录 下 的 byte. txt 与 char. txt 文件 删除 。 
主要 程序 代码 如 下 : 


protected void Bl Click (object sender, EventArgs e) 
{ 
FileStream fs -File.Create (Server .MapPath ("byte.txt")); 
byte[]b={97,98,99,100,101,102}; 
fs.Write (b,0,b.Length); 
fs.Close(); 
StreanWriter sw -File.CreateText (Server .MapPath ("char . txt") ) ; 
ebar[]e A 'B*, *C*,'p'*, '*E*, *F*); 
sw.Write (c); 
sw.Close(); 
Labell .Text = 你 已 创建 了 byte.txt 5j char.txt"; 


protected void B2_Click (object sender, EventArgs e) 
File.Copy (Server .MapPath ("char.txt") , Server .MapPath ("../char.txt")); 
protected void B3 Click(object sender, EventArgs e) 
File.Move (Server .MapPath ("byte txt") , Server.MapPath (" ../byte.txt")) ; 
protected void B4 Click (object sender, EventArgs e) 


File.Delete (Server .MapPath (" ../byte.txt")) ; 
File.Delete (Server.MapPath (" ../char.txt")); 


7.4 使 用 StreamReader 5j StreanWr iter 
类 读 写 文本 文件 
C# 滞 言 把 所 有 的 数据 源 ( 键 盘 \ 显 示 器 文件 网 络 ) 统 称 为 流 。 只 能 从 中 读 取 数据 ,不 能 
向 其 中 写 人 数据 的 流 称 为 输入 流 ; 只 能 向 其 中 写 和 数据 ,不 能 从 中 读 取 数据 的 流 称 为 输出 流 。 
7.4.1 使 用 StreamWriter 类 写 人 文本 文件 


1. 创建 StreamWriter 对 象 
StreanWriter 对 象 名 -new StreanWriter (path [,append] [,encoding]); 
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功能 : 创建 输出 流 对 象 ,用 于 指 代 path 指定 的 文本 文件 。 

(1) 参数 path 用 来 指定 文本 文件 的 路 径 , 若 文本 文件 不 存在 , 则 会 创建 该 文件 。 

(2) 参数 append 用 来 指定 是 否 将 文本 写 入 到 文件 末尾 。 若 取 true, 则 会 写 信 到 文件 的 
末尾 ; 若 取 false, 则 会 覆盖 文件 的 原来 内 容 ,默认 为 false。 

(3) Z encoding 用 来 指定 字符 编码 方式 ( Default、ASCIT、Unicode , UTF7 , UTF8 ) ,默认 
H System. Text. Encoding. UTF8 。 

例如 ， 


StreamWriter sw -new StreamWriter (Server .MapPath ("char .txt")) ; 


2. StreamWriter 对 象 的 属性 

AutoFlush = | true ,false| : 获取 或 设置 是 否 在 每 次 调用 Write( ) 或 WriteLine( ) 方 法 后 自 
动 将 缓冲 区 内 的 数据 写 和 文件 中 ,默认 为 hue。 若 将 AutoFlush 设置 为 true, 在 每 次 调用 
Write( ) 或 WriteLine( ) 方 法 后 ,SteamWriter 对 象 会 自动 调用 Plush( ) 方 法 。 


3. StreamWriter 对 象 的 方法 

(1) Write( 任 意 型 数据 ) : 将 各 种 类 型 的 数据 写 入 缓冲 区 中 。 例 如 ,sw. Write( 65 ) ; sw. 
Write( " student" ) ; 表示 将 整数 65 FITE "studen" 写 和 人 缓冲 区 中 。 

(2) Write ( charArray [ ,index][ ,count] ) : 从 字符 数组 charArray 下 标 为 index 的 元 素 
开始 ,将 连续 count 个 元 素 的 值 写 人 缓冲 区 中 。 若 省 略 参 数 index ,count, 则 将 字符 数组 
charArray 的 所 有 字符 写 人 缓冲 区 中 。 

(3) WriteLine( ) : 将 换行 符号 写 人 缓冲 区 中 。 

(4) Flush( ) : 将 缓冲 区 内 的 数据 写 入 文件 中 ,并 清除 缓冲 区 内 的 数据 。 若 没有 指定 
AutoFlush 属性 , 则 在 调用 Write( ) 或 WriteLine( ) 方 法 后 ,StreamWriter 对 象 会 自动 调用 Flush 
() 方 法 。 

(5) Close( ) : 关闭 StreamWriter 对 象 , 当 不 再 使 用 StreamWriter 对 象 时 ,一 定 要 关闭 
StreamWriter 对 象 ,否则 文件 将 被 锁定 。 调 用 此 方法 的 同时 也 会 将 缓冲 区 内 的 数据 写 入 文 
件 中 。 


7.4.2. [Jf] StreamReader 类 读 取 文本 文件 


1. 创建 StreamReader 对 象 
StreamReader 对 象 名 -new StreamReader (path [,encoding]); 


功能 : 创建 输入 流 对 象 ,用 于 指 代 path 指定 的 文本 文件 ,并 将 文件 指针 指向 首 字符 。 

(1) 参数 path 指定 的 文本 文件 必须 实际 存在 ,否则 会 发 生 错 误 。 

(2) 参数 encoding 用 来 指定 字符 编码 方式 ( ASCIT、Unicode、UTF7 , UTF8 ) , 默认 为 
System. Text. Encoding. UTF8 。 


2. StreamReader 对 象 的 方法 
(1) Read( ) : 从 输入 流 中 读 取 一 个 字符 ,并 返回 该 字符 的 Unicode 码 。 若 已 到 达 文 件 
尾 , 则 返回 -1。 


(2) Read( charArray ,index , count) : 从 输入 流 中 读 取 count 个 字符 , 存 人 下 标 从 index FF 
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始 的 字符 数组 charArray 中 。 


(3) ReadLine( ) : 从 输入 流 中 读 取 一 行 字符 ,返回 String 类 型 值 。 若 已 到 达 文 件 尾 , 则 


返回 null。 


(4) Close( ) : 关闭 StreamReader 对 象 , 当 不 再 使 用 StreamReader 对 象 时 ,一定 要 关闭 


StreamReader 对 象 ,否则 文件 将 被 锁定 。 


[907-4] 在 站 点 的 Stream 目录 下 添加 一 个 名 称 为 StreamReader. aspx 的 网 页 ,在 网 页 


中 添加 “ 写 文件 ”和 *“ 读 文件 ”两 个 按钮 ,用 于 验证 StreamReader 与 StreamWriter 类 的 应 用 。 
主要 程序 代码 如 下 : 


protected void Bl Click (object sender, EventArgs e) 


{ 


} 


// 创 建 指定 的 文本 文件 , 若 指 定 的 文件 已 经 存在 , 则 将 其 覆盖 
StreanWriter sw =new StreanWriter (Server.MapPath ("Poetryl .txt"), false); 
sw.Write ("唐诗 三 百 首 "); 

sw.WriteLine ("七 言 律诗 "); 

Sw.WriteLine(); 

sw .WriteLine ("登高 (杜甫 著 )") ; 

Sw.WriteLine(); 

sw.WriteLine ("JU X I JR EE , TE UP E385 gl n) ; 

sw. WriteLine ("EHKAM F ,不 尽 长 江 滚滚 来 。") ; 
sw.WriteLine ("万 里 翡 秋 常 作客 ,百年 多 病 独 登台 。") ; 
sw.WriteLine (" 艰 难 苦 恨 繁 霜 掺 , 渡 倒 新 停 间 酒杯 。") ; 
sw.Close(); 

B2.Visible -true; 


protected void B2 Click (object sender, EventArgs e) 


i 


StreamReader 类 „StreamWriter 类 以 字符 为 单位 读 取 及 写 入 数据 ,但 FileStream 类 以 字 节 
为 单位 读 取 及 写 人 数据 。 利 用 FileStream 类 既 可 以 读 取 数据 , 又 可 以 写 入 数据 , 即 


// 以 只 读 的 方式 打开 文本 文件 ,并 返回 StreamReader 对 象 
StreamReader sr -new StreamReader (Server.MapPath ("Poetryl.txt")); 
String Line -sr.ReadLine () ; 
while (Line! -null) 
{ 
Response.Write (" «Pre >" tLine +" </Pre >"); 
Line -sr.ReadLine(); 
) 


sr.Close(); 


7.5 使 用 FileStream 类 读 写 文本 文件 


FileStream 对 象 既是 输入 流 ,又 是 输出 流 。 
1. 创建 FileStream 对 象 
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FileStream 对 象 名 new FileStream (path,mode [,access]) ; 


功能 : 创建 FileStream 对 象 ,用 于 指 代 path 指定 的 文本 文件 。 

(1) 参数 path 指定 要 读 取 或 写 人 的 文本 文件 的 路 径 。 

(2) 参数 mode 指定 文件 的 打开 模式 ,可 以 取 以 下 两 个 值 。 

(D FileMode. Open: 打开 文件 , 若 文件 不 存在 , 则 产生 异常 错误 。 

@ FileMode. OpenOrCreate: 打开 文件 , 若 文件 不 存在 , 则 创建 文件 。 
(3) 参数 access 用 来 指定 文件 的 访问 类 型 ,可 以 取 以 下 3 个 值 。 

@ FileAccess. Read; 文件 只 可 读 取 。 

(2) FileAccess. Write; 文件 只 可 写 入 。 

@ FileAccess. ReadWrite; 文件 可 读 取 及 写 人 ,此 为 默认 值 。 

例如 : 


FileStream fs -new FileStream(Server.MapPath ("myText.txt") , FileMode.Open, 
FileAccess.ReadWrite); 


2. FileStream 对 象 的 方法 
(1) ReadByte( ) : 从 流 中 读 取 一 个 字 节 ,并 返回 该 字 节 的 ASCI 码 。 


(2) Read( byteArray , index , count) : 从 流 中 读 取 count 个 字 节 , 存 人 下 标 从 index 
字 节 数组 byteArray 中 。 


始 的 


(3) Seek(n,begin) : 将 文件 指针 向 右 移 过 nm 个 字 节 ,参数 begin 存在 以 下 3 种 取 值 。 


(D SeekOrigin. Begin: 从 文件 的 起 点 (第 一 个 字符 ) 开始 向 右 移动 。 
Q SeekOrigin. Current; 从 当前 的 指针 位 置 开 始 向 右 移动 。 
(3) SeekOrigin. End; 从 文件 的 尾 端 (最 后 一 个 字符 的 后 面 ) 开始 向 右 移动 。 


(4) Close( ) : 关闭 FileStream 对 象 , 当 不 再 使 用 FileStream 对 象 时 ,一 定 要 关闭 FileSteam 


对 象 ,否则 文件 将 被 锁定 。 


(5) WriteByte(n): 将 n 对 应 的 字符 写 和 人流 中 。 例 如 ,fs. WriteByte(65) ;表示 将 字符 A 


25 Af fs P 

(6) Write( byteArray ,index count) ; 从 字 节 数组 byteArray 下 标 为 index 的 元 素 开始 ,将 
连续 count 个 元 素 的 值 写 人 流 中 。 

【 例 7-5】 在 站 点 的 Stream 目录 下 添加 一 个 名 称 为 FileStream. aspx 的 网 页 ,用 于 验证 
FileStream 类 的 应 用 。 

主要 程序 代码 如 下 : 


protected void Page Load (object sender, EventArgs e) 
ji 
// 打 开 文 本 文件 ,并 返回 FileStream X1 
FileStream fs -new FileStream (Server .MapPath ("Poetry2 .txt") , 
FileMode.Open, FileAccess.ReadWrite); 


fs.Seek (0, SeekOrigin.End) ; // 使 文件 指针 指向 文件 的 末尾 
fs .WriteByte (65) ; 
fs .Seek (0, SeekOrigin.Begin); // 使 文件 指针 指向 文件 的 开头 


byte[]b new byte [fs .Length]; 
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fs .Read (b,0,b.Length) ; 

// 将 字 节 数组 转换 为 字符 串 

String Content -System.Text .Encoding.Default.GetString (b) ; 
Response.Write (" «Pre >" 4Content +" </Pre >") ; 

fs.Close(); 


716 文件 的 上 传 


文件 上 传 是 一 个 相当 实用 的 功能 , 它 人 允许 浏览 者 将 文件 上 传 至 服务 器 的 某 个 位 置 。 
ASP. NET 提供 的 HtmlInputFile 控件 使 用 户 无 须 依赖 任何 软件 ,就 可 以 完成 文件 的 上 传 。 
HtmlInputFile 控件 所 在 的 表单 必须 加 入 enctype =" multipart/form-data" 语句 ,也 就 是 写 


成 <form id =" forml" runat = " server" enctype = " multipart/form-data" > 。 


1. HtmlinputFile 控件 的 属性 

(1) MaxLength =n: 设置 文件 路 径 的 最 大 长 度 , 单 位 为 字符 。 

(2) Size =n: 设置 控件 的 宽度 ,单位 为 字符 。 

(3) PostedFile; 获取 上 传 的 文件 , 它 是 一 个 HttpPostedFile 对 象 ,包含 的 属性 与 方法 如 
表 74 所 示 。 


X74  PostedFile 包含 的 属性 与 方法 


属性 与 方法 说 9 
ContentLength 获取 上 传 文件 的 大 小 
ContentType 获取 上 传 文件 的 类 型 
FileName 获取 文件 在 客户 端的 完整 路 径 ,例如 D ; TT Beauty. jpg 
SaveAs ("文件 将 上 传 的 文件 以 指定 文件 名 保存 在 服务 器 中 。 若 服务 器 上 已 存在 同 
名 ") 名 的 文件 , 则 将 其 覆盖 


2. 将 字符 串 分 隔 成 若干 子 串 
格式 如 下 : 


String[]a “FF .split (字符 数组 名 ) 
功能 : 以 数组 中 的 某 些 字符 为 分 隔 符 , 将 字符 串 分 隔 成 若干 子 串 ,并 存 人 字符 串 数组 
a 中 。 例 如 : 


void Page Load (Object sender, EventArgs e) 
{ char[]c-('u','e'); 
String[]a -"studentend" . Split (c) ; 
foreach (string x in a) 
{Response.Write (x +", ");} 
) 


运行 结果 如 下 : 


st,d,nt,nd, 
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[507-6] 在 站 点 的 upload 目录 下 添加 一 个 名 称 为 upload1. aspx 的 网 页 ,初始 界面 如 
图 7-3 所 示 。 要 求 上 传 的 文件 被 存放 在 upload Miles 目录 下 。 


| ws Em 
| 清洁 择 上 传 的 文件 O REC Je eem 
| Es) 

图 7-3 (57-6 初始 界面 


主要 程序 代码 如 下 : 


protected void bl click (object sender, EventArgs e) 
{ 
// 取 出 上 传 文件 的 名 称 
String[]a &F1.PostedFile.FileName.Split (' WV) ; 
String str =", fs ="; 
foreach (string x in a) 
{ fs=x; } 
str "上 传 的 文件 名 为 :" +fs + <br >"; 
str += 文 件 类 型 为 :" +F1.PostedFile.ContentType +" «br >"; 
str + 文件 长 度 为 :" +1 . PostedFile.ContentLength; 


if (File.Exists (Server.MapPath ("files/" +fs)) ==false) 
{ 
Labell .Text =TextBoxl .Text +", {i}! «pr > +str; 
Fl.PostedFile.SaveAs (Server .MapPath ("files/" +fs)); 
} 
else Labell.Text "上 传 的 文件 名 已 存在 ! n7 


7.7 项 目 实 训 


实 训 1 在 浏览 器 中 显示 网 页 的 源 代码 

实 训 目 的 

(1) 熟练 掌握 文本 文件 的 读 取 方法 。 

(2) 学 会 在 浏览 器 中 显示 网 页 的 源 代 码 。 

实 训 要 求 

(1) 创建 一 个 Web 网 站 sx07 ,并 设置 成 虚拟 目录 ,在 网 站 中 添加 Images 文件 夹 。 

(2) 在 站 点 中 添加 一 个 名 称 为 sx7_1. aspx 的 网 页 ,要 求 : 当 单 击 “ 显 示 ” 按 钮 时 ,能 将 
File. aspx 网 页 的 源 代 码 显示 到 浏览 器 中 。 

实 训 提 示 


protected void Bl Click (object sender, EventArgs e) 
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StreamReader sr new StreamReader (Server.MapPath ("File.aspx")); 
String Line -sr.ReadLine () ; 
while (Line! -null) 
{ 
Response.Write (Server.HtmlEncode (Line) +" «br >"); 
Line -sr.ReadLine|() ; 
) 
sr.Close(); 


} 


实 训 2” 列 出 文件 夹 中 的 文件 
实 训 目 的 
(1) 掌握 将 文件 夹 中 的 图 片 文件 添加 到 组 合 框 中 的 方法 。 
(2) 学 会 用 Image 控件 显示 从 组 合 框 中 选中 的 图 片 。 
(3) 掌握 删除 文件 的 方法 。 
实 训 要 求 
(1) 在 站 点 中 添加 一 个 名 称 为 sx7_2. aspx 的 网 页 ,网 页 的 初始 界面 如 图 74 所 示 。 


si 
图 74 实 训 2 初始 界面 


(2) 将 Images 文件 夹 中 的 图 片 文件 显示 到 组 合 框 中 ,当选 择 一 个 图 片 文 件 时 ,相应 的 
图 片 就 会 显示 到 Images 控件 中 。 此 时 , 若 单 击 * 删 除 "按钮 , 则 会 将 图 片 文 件 从 站 点 中 删除 。 


实 训 提示 
将 Images 文件 夹 中 的 图 片 文件 显示 到 组 合 框 中 ,代码 如 下 : 


protected void Page Load (object sender, EventArgs e) 
{ 
String[]a Directory.GetFiles (Server.MapPath ("Images") , " * ") ; 
foreach (String x in a) 
{ 
String fn=""; 
String[]b=x.Split ('\\'); 
foreach (String y in b) 
{fn=y; } 
DropDownList1 . Items .Add (fn) ; 
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思考 与 练习 
一 、 填空 题 
1. 在 使 用 System. IO 命名 空间 的 类 之 前 ,必须 先导 入 System. 10 命名 空间 , 代码 
为 


2. StreamReader 类 以 为 单位 


数据 ，StreamWriter 类 以 为 单 
为 单位 读 取 及 写 入 数据 。 

3. 只 能 从 中 读 取 数据 ,不 能 向 其 中 写 和 数据 的 流 称 为 流 ;只 能 向 其 中 写 人 数 
据 , 不 能 从 中 读 取 数据 的 流 称 为 流 。 


二 、 简 答题 
1. Directory 类 有 哪些 功能 ? 
2. File 类 有 哪些 功能 ? 


位 数据 ,但 FileStream 类 以 
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ASP. NET 提供 了 两 种 类 型 的 配置 文件 ,分 别 是 服务 器 配置 文件 和 应 用 程序 配置 文件 。 
本 章 将 主要 介绍 如 何 运 用 Web. config 配置 文件 和 Global. asax 配置 文件 对 网 站 环境 进行 配 
置 ,以 及 如 何 运 用 主题 和 母 版 页 对 网 站 进行 优化 ,创建 具有 统一 布局 和 风格 的 网 站 。 


aR 


* 了 解 Web. config 配置 文件 的 特点 和 结构 

掌握 Web. config 文件 的 配置 方法 

掌握 Global. asax 文件 的 配置 方法 

掌握 主题 的 组 成 和 将 主题 应 用 到 网 页 中 的 方法 
熟悉 母 版 页 和 内 容 页 的 创建 方法 


8.1 使 用 Web. config 进行 配置 


ASP. NET 提供 了 一 个 丰富 而 可 行 的 配置 系统 ,方便 网 络 管理 员 对 Web 应 用 站点、 机 
器 分 别 进行 不 同 的 配置 ,帮助 管理 人 员 轻 松 、 快 速 地 建立 自己 的 Web 应 用 环境 。ASP. NET 
提供 了 两 种 类 型 的 配置 文件 : 服务 器 配置 文件 Machine. config 和 应 用 程序 配置 文件 
Web. config。 配 置 文件 都 是 系统 自动 生成 的 ,文件 名 不 能 随意 改动 。 

ASP. NET 配置 系统 主要 有 以 下 优点 。 

(1) 配置 信息 存储 在 基于 XML 格式 的 文件 ( Machine. config 和 Web. config) 中 ,可 以 以 
任意 标准 的 文本 编辑 器 .XML 解析 器 和 脚本 语言 解释 ,修改 配置 文件 。 

(2) 所 有 配置 的 更 新 是 即时 的 ,无 须 重启 Web 服务 器 ,就 能 将 配置 应 用 于 正在 运行 的 
系统 。 

(3) 配置 系统 是 一 个 可 扩展 的 层次 配置 架构 ,支持 第 三 方 开 发 者 配置 自己 的 内 容 。 

通常 在 一 个 系统 中 只 能 有 一 个 Machine. config 文件 , 它 一 般 位 于 WINDOWS \ Microsoft 
. NET\ Framework \v2. X\CONFIG 目录 下 ,用 于 描述 所 有 Web 应 用 程序 的 默认 设置 。 而 一 个 
系统 可 以 有 多 个 Web. config 文件 。 在 页 面 启动 时 ,首先 读 取 的 是 Machine. config 文件 的 内 
容 ,获得 相应 的 机 器 配置 信息 ,然后 一 层 一 层 地 读 取 所 有 Application 根 目 录 下 的 Web. config 
文件 的 内 容 , 根 据 它 的 内 容 对 Machine. config 文件 中 的 配置 进行 修改 或 补充 。 而 Machine. 
config 文件 和 Web. config 文件 在 语法 上 没有 任何 的 区 别 。 下 面 仅 介绍 Web 
. config 配置 文件 的 特点 和 结构 。 


172 


ASP. NET 网 站 开发 案例 教程 


8.1.1 Web. config 文件 的 特点 


在 每 一 个 ASP. NET 应 用 程序 的 目录 中 都 包含 一 个 Web. config 文件 。 通 常 
Web. config 文件 有 以 下 几 个 特点 。 

(1) Web. config 文件 用 于 对 IIS 或 Page 指令 进行 配置 ,不 能 直接 访问 。 

(2) Web. config 文件 位 于 站 点 的 各 个 目录 中 , 它 决定 了 所 在 目录 及 其 子 目录 的 配置 信 
息 ,并 且 子 目录 的 配置 信息 会 覆盖 父 目录 的 配置 信息 。 

(3) 当 访 问 某 个 页 面 时 ,首先 读 取 Machine. config 文件 与 站 点 根 目录 下 的 Web. config 
文件 ,然后 从 上 到 下 读 取 各 子 目录 下 的 Web. config 文件 ,最 后 读 取 当前 页 面 所 在 目录 下 的 
Web. config 文件 ,再 执行 当前 页 面 。 


8.1.2. Web. config 文件 的 结构 


Web. config 配置 文件 的 配置 内 容 包含 在 标记 < configuration > 和 < /configuration > 之 
间 ,注释 语句 则 包含 在 符号 ” <! --” 和 “-- > "之 间 。Web. config 的 配置 内 容 主要 包含 
4 部 分 : 配置 节 处 理 程序 声明 ,应 用 程序 设置 < connectionStrings > 和 配置 节 设 置 。 


1. 配置 节 处 理 程序 声明 

配置 节 处 理 程序 声明 一 般 位 于 配置 文件 顶部 的 < configSections > 和 </configSections > 标记 
之 间 , 声 明 各 个 配置 节 对 应 的 节 处 理 程序 。 默 认 的 Web. config 文件 中 没有 < configSections > 
和 </configSections > 标记 , 如 果 需 要 ,可 以 自己 添加 。 配 置 节 处 理 程序 声明 的 语法 格式 
如 下 : 

<configSections > 

«section name "配置 节 名 称 " type =" 节 处 理 程序 "/ > 


«section name "配置 节 名 称 "” type =" 节 处 理 程序 "/ > 
</configSections > 


2. 应 用 程序 设置 

应 用 程序 设置 一 般 位 于 配置 文件 的 < appSettings > 和 </appSettings > 标记 之 间 , 用 于 定 
义 自己 需要 的 应 用 程序 设置 项 ,其 语法 格式 如 下 : 

<appSettings > 

«add key -"[key]" value =" [value] "/ > 

«/appSettings > 

其 中 ,key 属性 用 于 指定 设置 项 的 名 称 ,便于 在 程序 中 引用 。value 属性 用 于 指定 设置 项 
的 值 。 

【 例 8-1】 在 Web. config 文件 中 指定 要 连接 的 数据 库 。 

«appSettings > 

<add key-"SQL" value="server =localhost . ;uid =sa;pwd =;database -stu"/ > 

<add key="Access" value -"provider Microsoft. Jet. OLEDB. 4 . 0; data source =" +Server. 

MapPath ("images/stu.mdb") / > 
</appSettings > 
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TE. aspx 页 面 中 使 用 “sql = ConfigurationSettings. AppSettings| " SQL" ] ; "可 得 到 数据 库 连 
接 字符 串 。 

3. «connectionStrings > 

< connectionStrings > 一 般 位 于 配置 文件 的 < connectionStrings > 和 « /connectionStrings > 
标记 之 间 ,用 于 定义 自己 需要 的 应 用 程序 设置 项 ,其 语法 格式 如 下 : 

<connectionStrings > 


«add name "HEA"  connectionString 一 设置 值 "/ > 
</connectionStrings > 


【 例 8-2】 在 Web. config 文件 中 指定 要 连接 的 数据 库 。 


<connectionStrings > 
<add name -"SQL"  connectionString -"Data Source =localhost; DataBase -stu; User ID = 
Sa;Password =; "/ > 
<add name =" Access" connectionString -"Provider -Microsoft.Jet.OLEDB.4.0;Data Source 
7" Server .MapPath ("images/stu .mdb") / > 
X/connectionStrings > 


在 . aspx 页 面 中 使 用 : 

string sql -Convert . ToString (ConfigurationManager.ConnectionStrings ["SQL"]) ; 
得 到 数据 库 连接 字符 串 。 

4. RE DIRE 

配置 节 设 置 一 般 位 于 配置 文件 的 < system. web > 5j « /system. web > 标记 之 间 ,可 以 完 
成 大 多 数 网 站 参数 的 设置 。 多 数 配置 节 都 可 以 放 在 任意 目录 下 的 配置 文件 中 ,但 个 别 配置 
节 只 能 放 在 站 点 根 目录 下 的 配置 文件 中 ,下面 列 出 几 个 常见 的 配置 节 的 具体 含义 和 用 法 。 

(1) <compilation > 

< compilation > 配置 只 能 放 在 根 目 录 下 的 配置 文件 中 ,用 于 配置 ASP. NET 的 编译 环境 ， 
其 配置 范例 如 下 : 


«compilation defaultLanguage = "cf' debug -"true" /> 


其 中 ,defaultLanguage 属性 用 于 定义 所 使 用 的 后 台 代 码 语言 ,可 以 使 用 C# 或 Visual 
Basic. NET, debug 属性 用 于 设置 是 否 启用 ASPX 调试 ,debug 属性 值 为 hue 时 将 启用 ASPX 
调试 。 通 常 在 程序 调试 阶段 设 为 rue, 当 编译 出 错时 ,显示 完整 的 编译 源 。 当 测试 完成 后 应 
该 设 为 false, 可 以 提高 程序 的 运行 性 能 。 

(2) «customErrors > 

支持 用 户 编写 自 定义 错误 页 面 , 在 发 生 特定 的 错误 时 ,将 浏览 器 重 定向 到 某 个 URL ,其 
配置 范例 如 下 : 

«custonErrors mode -"On" defaultRedirect ="1.htm" > 

«error statusCode ="400" redirect —"2.htm" /> 


«error statusCode ="404" redirect -"3.htm" /> 
X/customErrors > 
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解释 : 当当 前 页 面 发 生 错误 时 ,就 跳 转 到 其 他 页 面 。 当 错误 代码 为 400 或 404 时 , 则 跳 
转 到 2. htm 或 3. htm; AI , 跳 转 到 1. htm, 

其 中 ,各 属性 说 明 如 下 : 

(D mode 属性 : 设置 错误 模式 。 共 有 3 种 模式 , On: 表示 始终 显示 自 定义 的 信息 ; Off; 
表示 始终 显示 详细 的 ASP. NET 错误 信息 ;RemoteOnly: 默认 值 , 表 示 只 对 不 在 本 地 Web 服 
务 器 上 运行 的 用 户 显示 自 定 义 的 信息 。 

@ defaultRedirect: 当当 前 页 面 出 现 错误 时 ,如 果 没 有 通过 < error > 标记 处 理 该 错误 ,就 
会 重 定向 到 defaultRedirect 指定 的 URL 地 址 。 

(8) statusCode: 指明 错误 状态 码 。 

(4) redirect; 发 生 对 应 的 错误 状态 码 时 ,应 该 重 定向 到 的 URL 地 址 。 

(3) «sessionState > 

< sessionState > 配置 只 能 放 在 根 目 录 下 的 配置 文件 中 为 每 个 上 线 用 户 设置 会 话 状态 , 
其 配置 范例 如 下 : 


«sessionState mode -"InProc" cookieless -"true" timeout —"20"/ > 


其 中 ,各 属性 说 明 如 下 : 

(D mode 属性 : 指定 会 话 状 态 的 存储 位 置 。 它 有 Off, InProc 、StateServer , SQLServer 共 
4 种 取 值 。0ff 表示 禁用 会 话 状 态 ;InProc 表示 在 本 地 保存 会 话 状 态 ;StateServer 表示 在 远程 状 
态 服务 器 上 保存 会 话 状态 ;SQLServer 表示 将 会 话 信息 保存 到 SQL Server 数据 库 中 。 

(2) cookieless: 用 于 设置 是 否 使 用 Cookie 保存 会 话 状 态 ,默认 值 为 false。 

@ timeout; 用 来 定义 会 话 状态 维持 时 间 ,超过 期 限 则 停止 会 话 , 默 认为 20 分 钟 。 

@ < sessionState mode =" InProc"/ > 5j <% @ Page EnableSessionState = " true" % > 
等 价 。 

(4) <httpRuntime > 

设置 连接 超时 期 限 ,其 配置 范例 如 下 : 


<httpRuntime executionTimeout -"90"/ > 


(5) <pages > 
通过 < pages > 配置 可 以 控制 . aspx 页 面 的 一 些 默认 行为 , 它 与 Page 指令 相对 应 。 
其 配置 范例 如 下 : 


«pages styleSheetTheme "主题 1" buffer-"true" enableViewState ="true" 
enableSessionState -"true" autoEventWireup ="true"/ > 


(6) «authorization > 
< authorization > 配置 只 能 放 在 根 目录 下 的 配置 文件 中 ,用 于 设置 应 用 程序 的 授权 策 
略 , 其 语法 定义 如 下 : 
«authorization» 
«allow users 下 [用 户 列表 ]" roles 一 [角色 列表 ]"/ > 
«deny users "UH P SIR ]" roles 一 [角色 列表 ]"/ > 


</authorization > 


其 中 ,allow 标记 用 于 设置 允许 的 用 户 ,deny 标记 用 于 设置 禁止 的 用 户 。 列 表 中 如 果 包 
含 多 个 用 户 , 则 使 用 逗号 隔 开 。 可 使 用 通配符 ” * "表示 任何 人 ， 


验证 的 ) 用 户 。 


(7) <trace > 
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用 来 实现 ASP. NET 应 用 程序 的 错误 跟踪 服务 ,其 配置 范例 如 下 : 


«trace enabled -"true" requestLimit ="10" pageOutput ="false" traceMode ="SortByTime"/ > 


其 中 ,各 属性 说 明 如 下 : 


(D enabled; 指定 是 否 启用 应 用 程序 跟踪 。 

Q) requestLimit: 指定 存放 在 服务 器 上 的 跟踪 请 求 数目 ,默认 值 为 10。 
@ pageOutput: 设置 是 否 在 每 页 的 底部 显示 跟踪 信息 。 

@ traceMode: 设置 跟踪 的 模式 ,默认 为 按时 间 排 序 ( SortByTime) 。 


8.2 使 用 Global.asax 进行 配置 


Global. asax 文件 (又 称 为 ASP. NET 应 用 程序 文件 ) 是 可 选 的 配置 文件 ,该 文件 包含 响 


应 ASP. NET 或 HTTP 模块 引发 的 应 


会 话 状 态 的 开始 和 结束 等 。 它 驻 留 在 ASP. NET 应 用 程序 所 在 的 根 目 录 下 。 当 第 一 次 请 求 
程序 中 的 资源 或 URL 时 ,ASP. NET 会 自动 将 这 个 文件 编辑 成 一 个 . NET Framework 类 ,该 类 
继承 自 HttpApplication JEJE. Global. asax 文件 本 身 被 设置 为 拒绝 客户 端 对 它 的 任何 直接 


应 用 程序 级 别 事件 的 代码 ,例如 ,应 用 程序 的 


URL 请 求 , 所 以 外 部 用 户 无 法 下 载 或 查看 该 文件 中 的 代码 。 
8.2.1 Global. asax 文件 的 结构 


创建 Global. asax 文件 的 方法 很 简单 , 右 击 站 点 根 目录 ,在 弹出 的 快捷 菜单 中 选择 “添加 
新 项 "命令 ,在 打开 的 对 话 框 中 选择 “全 局 应 用 程序 类 "选项 ,如 图 8-1 所 示 , 这样 就 创建 了 


Global. asax 文件 。 


添加 新 项 - E:\ 个 人 教学 资料 \ 教 材 编写 \ 清 华 大 学 出 版 社 \ 各 章 实 例 \chap08\ 
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图 8-1 新 建 Global. asax 文件 界面 
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Global. asax 文件 必须 位 于 站 点 的 根 目录 下 ,Global. asax 文件 的 默认 结构 如 下 : 


«$8 Application Language -"Cf'$ > 
«script runat -"server" > 
void Application Start (object sender, EventArgs e) 
{ // 在 应 用 程序 启动 时 运行 的 代码 。 } 
void Application End (object sender, EventArgs e) 
{ // 在 应 用 程序 关闭 时 运行 的 代码 。 } 
void Application Error (object sender, EventArgs e) 
{ // 在 出 现 未 处 理 的 错误 时 运行 的 代码 。 “} 
Void Session Start (object sender, EventArgs e) 
{ // 在 新 会 话 启动 时 运行 的 代码 。 } 
Void Session End (object sender, EventArgs e) 
{ // 在 会 话 结束 时 运行 的 代码 。 } 
</script > 


当 访问 一 个 网 页 时 , ASP. NET 系统 首先 读 取 各 级 目录 的 Web. config 文件 ,再 读 取 
Global. asax 文件 ,并 把 < script > 块 内 的 代码 编译 为 . NET. 框架 类 ( 即 System. Web. 
HttpApplication 的 子 类 ) ,最 后 执行 当前 网 页 。 

定义 在 Global. asax 内 的 成 员 是 事件 处 理 程序 ,这 些 事件 处 理 程序 允许 用 户 与 应 用 程序 
级 (以 及 会 话 级 ) 事 件 交互 。 表 8-1 列 出 了 Global. asax 内 每 个 成 员 的 作用 。 

表 8-1 Global. asax 内 的 成 员 


事件 处 理 程序 作 用 

nv 当 启动 Web 服务 器 或 修改 Global. asax .Global. asax. cs 文件 的 内 容 时 
Application, Start( ) 就 会 触发 该 事件 
Application End( ) 在 应 用 程序 关闭 时 就 触发 该 事件 
Application_Error( ) 程序 出 错时 触发 该 事件 
"T 创建 一 个 Session 对 象 时 就 会 自动 触发 该 事件 。 直 接 打 开 TE 会 触发 
Session Start( ) 该 事件 
Session End( ) 当 调用 Session. Abandon( ) 方 法 或 会 话 过 期 时 会 自动 触发 该 事件 ,但 
mem 直接 关闭 TE 不 会 触发 该 事件 


8.2.2 使 用 Global. asax 文件 进行 配置 


Global. asax 文件 最 常用 的 应 用 就 是 处 理 8.2. 1 小 节 中 讲述 的 全 局 事件 ,这 些 事件 是 针 
对 整个 应 用 程序 的 事件 ,而 不 是 针对 某 个 特定 的 页 面 。 下 面 将 通过 一 个 实例 来 介绍 如 何 使 
用 Global. asax 文件 进行 配置 。 

【 例 8-3】 统计 网 站 的 在 线 人 数 的 总 访问 量 。 

(1) 将 Global. asax 文件 的 代码 后 置 到 Global. asax. es, DLE Global. asax 文件 中 添加 以 
下 代码 : 


<%@ Application CodeBehind ="Global .asax.cs" Inherits =" Global" Language -"Cf %> 


(2) 在 App. Code 文件 夹 下 创建 一 个 Global. asax. es 文件 ,该 文件 仅 含 Global 类 (继承 
FH System. Web. HttpApplication) ,其 代码 如 下 : 


public class Global:System.Web.HttpApplication 
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void Application Start (Object sender, EventArgs e) 
{ 


// 当 启动 Web 服务 器 或 修改 Global.asax 或 Global .asax.cs 文件 的 内 容 时 就 触发 该 事件 


Application.lock(); 


Application["Online"] -0; // 记 录 当 前 在 线 人 数 
Application["CountAll"] -0; // 记 录 总 访问 量 


Application.UnLock () ; 

) 

void Application End(object sender, EventArgs e) 

{ 
// 在 应 用 程序 关闭 时 运行 的 代码 

} 

void Application Error (object sender, EventArgs e) 

{ 
// 在 出 现 未 处 理 的 错误 时 运行 的 代码 

) 

void Session Start (object sender, EventArgs e) 

{ 
// 创 建 一 个 Session 对象 时 就 触发 该 事件 
Session.Timeout =L; // 设 置 会 话 期 限 为 1 分 钟 
Application.Lock(); 
Application ["Online"] -(int)Application["Online"] 41; 
Application ["CountAll"] -(int)Application["CountAll"] 41; 
Application.UnLock () ; 

) 

void Session End(object sender, EventArgs e) 

{ 
// 当 调用 Session.Abandon () 方 法 或 会 话 过 期 时 会 自动 触发 该 事件 
Application.Lock(); 
Application["Online"] -(int)Application |["Online"] 31; 
Application.UnLock (); 


} 
(3) 创建 一 个 名 称 为 count. aspx 的 网 页 ,初始 界面 如 图 8-2 所 示 。 


当前 在 线 人 数 Eabel 

网 站 访问 量 Eabel 

SessionID Fabel 
AREE 


图 8-2 count. aspx 网 页 的 初始 界面 


在 count. aspx. cs 文件 中 编写 如 下 代码 : 


protected void Page Load (object sender, EventArgs e) 
| 
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Labell.Text -Application["Online"].ToString(); 
Label2 .Text -hpplication["CountAll"] .ToString(); 
label3.Text -Session.SessionID; 
) 
protected void Buttonl Click (object sender, EventArgs e) 
{ 
Session.Abandon () ; 
} 
程序 说 明 : 当 访问 count. aspx 页 面 时 ,首先 读 取 Global. asax 文件 ,如 果 刚 启动 Web 服 
务 器 或 刚 修改 Global. asax 文件 的 内 容 就 会 触发 Application_Start( ) 事 件 ,将 在 线 人 数 .总 访 
问 量 均 置 0。 接 着 ,由 于 打开 IE 开始 了 一 个 新 的 会 话 ,于 是 触发 Session_Start( ) 事 件 ,将 在 
线 人 数 总 访问 量 均 置 1 ,最 后 执行 当前 页 面 ,将 在 线 人 数 总 访问 量 显示 出 来 。 


8.3 主题 和 皮肤 


主题 和 皮肤 是 ASP. NET 2. 0 引入 的 新 概念 , 它 将 样式 和 布局 信息 分 解 为 单独 的 文件 
组 ,可 以 方便 地 控制 ASP. NET 页 面 的 外 观 。 将 主题 和 皮肤 . 母 版 页 站 点 导航 系统 三 者 结合 
在 一 起 ,可 以 打造 网 站 统一 的 整体 效果 。 


8.3.1 CSS 简介 


层 人 样式 表 或 级 联 样式 表 ( Cascading Style Sheet, CSS) 是 一 种 样式 语言 ,用 于 为 HTML 
文档 定义 布局 ,控制 Web 页 面 的 外 观 。 

在 互联 网 发 展 初期 ,HTML 语言 原本 被 设计 为 用 于 定义 文档 内 容 。 文 档 的 布局 是 由 浏 
览 器 来 完成 的 ,而 不 使 用 任何 的 格式 化 标记 。 由 于 两 种 主要 的 浏览 器 ( Netscape 和 Internet 
Explorer) 不 断 地 将 新 的 HTML 标记 和 属性 ( 比如 字体 标记 和 颜色 属性 ) 添加 到 HTML 规范 
中 ,使 得 创建 文档 内 容 清晰 地 独立 于 文档 表现 层 的 站 点 变 得 越 来 越 困 难 。CSS 由 此 而 诞生 
了 , 它 为 Web 设计 师 们 提供 了 完善 的 .所 有 浏览 器 都 支持 的 布局 功能 。 同 时 页 面 样式 与 内 
容 的 分 离 ,不 仅 可 使 维护 站 点 的 外 观 变 得 更 加 容易 ,而 且 还 可 以 使 HTML 文档 代码 更 加 简 
练 ,缩短 浏览 器 的 加 载 时 间 。 

1. CSS 的 基本 语法 

CSS 由 3 个 部 分 构成 : 选择 符 ( selector) ,属性 (properties) 和 属性 的 取 值 ( value ) o Bl. 

选择 符 { 样 式 表 定义 } 

例如 ,定义 段落 格式 为 : 字体 为 宋体 ,居中 排列 ,文字 为 红色 ,代码 如 下 : 

p { font -family: 宋 体 ;text -align:center;color:red } 

说 明 : 

(1) 选择 符 可 以 是 元 素 、 类 名 ID 名 , 见 表 8-2。 

(2) 在 定义 类 名 选择 符 时 ,必须 在 类 名 前 面 加 一 个 点 号 ;在 调用 类 名 选择 符 时 ,要 将 点 
号 去 掉 。 
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X852 选择 符 分 类 

选择 符 样式 表格 式 调 用 作 用 域 
元 素 | 样 式 表 定义 | 

元 素 例如 : 自动 调用 整个 网 页 的 所 有 同名 元 素 
pícolor:red) 
.类 名 | 样式 表 定义 | < 元 素 class = "类 名 " > 

类 名 例如 : 例如 : 调用 类 名 的 元 素 
-chen(color:red] <p class -"chen" > 
HD 名 | 样式 表 定义 | < 元 素 ID=" 名 " > 

ID 名 例如 : 例如 : 调用 ID 名 的 元 素 
&hen(color:red] <p ID-"chen" > 


(3) 选择 符 组 : 多 个 选择 符 可 以 共用 一 个 样式 表 , 例 如 : 
td, .c01, £hen(font -size:12pt; font -family: 宋 体 } 


(4) 包含 选择 符 : 为 指定 范围 内 的 元 素 定义 样式 表 。 
例如 ,为 表格 内 的 链接 改变 样式 ,文字 大 小 为 10 像素 ,而 表格 外 的 链接 的 文字 仍 为 默认 
大 小 ,代码 如 下 : 


tablea { font -size:10px } 


(5) 注释 : 用 来 解释 代码 ,方便 程序 员 编辑 和 更 改 代码 时 理解 代码 的 含义 。CSS 和 C 
语言 一 样 ,采用 /* 注释 */ 格式 。 


2. 样式 表 的 类 型 
(1) 元 素 内 定 样式 表 : 直接 利用 HTML 标记 指定 其 样式 。 
例如 : 


«input id -"Buttonl" style -"color:blue; font -style:italic; font -family: 仿 宋 ;text -align: 
center" type="button" value = 提交 按钮 "/ > 


(2) 嵌入 式样 式 表 : 首先 定义 CSS ,然后 利用 控件 的 class 或 id 属性 来 指定 其 样式 。 
[808-4] 嵌入 式样 式 表 的 定义 和 应 用 。 


<head > 
«style type ="text/css" > 
#extStype{ font -size:20pt;color :black; font -style:normal; font -family: 幼 圆 ; 
text -align:left] 
-bttonStype(color:blue;font -style:italic; font -family: 仿宋 ;text -align:center] 
</style > 
</head > 
«body > 
<input id-"Buttonl" type="button" class-"bttonstype" value 一 "提交 按钮 " /> 
<input id="Text1" type="text" id-"textstype" value= 文 本 框 "/ ></div> 
</body > 


(3) 级 联 样式 表 : 和 嵌入 式样 式 表 很 相似 ,但 是 把 CSS 存放 在 一 个 单独 的 . ess 文件 中 ， 
然后 在 需要 使 用 样式 的 页 面 中 使 用 < link > 标记 引入 ,这 样 就 能 实现 样式 和 页 面 内 容 的 分 
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离 ,不 仅 可 使 维护 站 点 的 外 观 变 得 更 加 容易 ,而 且 还 可 以 使 HTML 文档 代码 更 加 简练 ,缩短 
浏览 器 的 加 载 时 间 。 

[808-5] 级 联 样式 表 的 定义 和 应 用 。 

(1) 先 建立 一 个 外 部 CSS 文件 main-sheet. css ,代码 如 下 ; 


非 extStype 

{ font -size:20pt; 
color:black; 
font -style:normal7 
font -family: 幼 圆 ; 
text -align:left; 

} 

-bttonStype 

( color:blue; 
font -style:italic; 
font -family: 仿 宋 ; 
text -align:center 


) 

(2) 在 需要 使 用 此 样式 的 页 面 中 ,在 <head > </head > 内 部 ,使 用 如 下 代码 引入 . ess 文件 ; 
<link rel -stylesheet href -"main -sheet .css" type -"text/css" > 

引入 后 ,在 控件 上 的 使 用 方法 与 嵌入 式样 式 表 相同 。 


3. 利用 Visual Studio 2005 创建 样式 表 

Visual Studio 2005 提供 了 快速 创建 样式 表 的 工具 ,利用 该 工具 就 可 以 轻松 便捷 地 创建 
外 部 CSS 文件 。 具 体操 作 步 又 如 下 : 

(D 打开 “解决 方案 资源 管理 器 "视图 , 右 击 站 点 根 目 录 , 在 弹出 的 快捷 菜单 中 选择 
“添加 ASP. NET 文件 夹 "1“ 主 题 "命令 ,创建 “主题 1”。 

(2) 右 击 “ 主 题 1” ,在 弹出 的 快捷 菜单 中 选择 “添加 新 项 "命令 ,然后 在 打开 的 “添加 新 
项 "对 话 框 中 选择 “样式 表 " 文件 ,在 名称" 文本 框 中 输入 文件 名 , 单 击 “ 添 加 "按钮 。 

(3) 在 “样式 " 主 菜单 中 选择 * 添 加 样式 规则 ”命令 ,打开 如 图 8-3 所 示 的 对 话 框 ,添加 
样式 规则 后 , 单 击 “确定 ”按钮 即 可 。 


法 加 样式 规则 
IER SRRA M 的 元 素 定义 新 样式 规则 。 可 以 村 附加 的 元 索 、 类 
和 » 


图 8-3 “添加 样式 规则 ”对 话 框 
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(4) 将 光标 放 在 CSS 文件 中 某 个 样式 表 的 内 部 ,选择 “样式 " 主 菜单 中 的 “生成 样式 " 命 


令 , 打 开 “ 样 式 生 成 器 "对 话 框 ,如 图 84 所 示 。 添 加 样式 内 容 后 , 单 击 “ 确 定 ” 按 钮 即 可 。 


样式 生成 器 - body 


图 84 自动 生成 样式 


8.3.2 主题 的 组 成 


将 样式 和 布局 信息 分 解 为 单独 的 文件 组 ,统称 为 "主题 ”, 它 影响 着 网 页 的 外 观 或 网 页 
中 某 些 控件 的 外 观 。 一 个 主题 可 包含 多 类 文件 : 皮肤 文件 (. skin) .级 联 样式 表 (. ess) KIK 
文件 和 其 他 资源 。 在 默认 情况 下 , 主题 存储 在 网 站 中 的 App. Themes 目录 下 ,App_Themes 
目录 下 可 包含 多 个 主题 。 

下 面 介绍 如 何 使 用 Visual Studio 2005 创建 主题 ,具体 操作 步骤 如 下 : 

(1) 打开 * 解 决 方案 资源 管理 器 "视图 , 右 击 站 点 根 目 录 , 在 弹出 的 快捷 菜单 中 选择 
“添加 ASP. NET 文件 夹 "1 “主题 "命令 ,这 样 就 在 站 点 的 App. Themes 目录 下 添加 了 一 个 
主题 。 

(2) 为 主题 添加 皮肤 文件 .样式 表 、 图 表 和 其 他 资源 。 

在 需要 添加 内 容 的 主题 文件 夹 上 右 击 ,在 弹出 的 快捷 菜单 中 选择 “添加 新 项 "命令 , 打 
开 * 添 加 新 项 "对 话 框 ,如 图 8-5 所 示 。 然 后 选择 需 添加 的 对 象 类 型 ,输入 名 称 , 单 击 “ 添 加 ” 
按钮 即 可 。 


8.3.3 皮肤 文件 


一 个 皮肤 文件 (外 观 文件 ) 可 定义 一 个 或 多 个 Web 控件 的 外 观 ,一 个 Web 控件 也 可 定 
义 多 种 外 观 ,只 要 将 Web 控件 的 ID 属性 去 掉 即 可 。 

通常 外 观 有 两 种 : 一 种 是 没有 指定 SkinID 属性 的 默认 外 观 ; 另 一 种 是 指定 了 SkinID 属 
性 的 命名 外 观 。 在 同一 个 主题 中 ,每 个 Web 控件 只 允许 有 一 个 默认 外 观 ,但 可 以 有 多 个 命 
名 外 观 。 当 为 一 个 网 页 应 用 主题 时 , 若 网 页 内 的 Web 控件 指定 了 SkinID 属性 , 则 使 用 这 个 
命名 外 观 所 定义 的 样式 ,否则 自动 使 用 同一 类 型 的 默认 外 观 。 
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添加 新 项 — E:\ 个 人 教学 资料 \ 教 材 编写 \ 清 华 大 学 出 版 社 \ 案 例 \chap08X 


TED: 
Visual Studio 已 安装 的 模板 
p ma r 
p 3s 文件 
PESSA] 
我 的 模板 


perean 


用 于 Rich ITIL 样式 定义 的 级 联 样式 表 


[StyleSheet2. css 


将 代码 放 在 单 灶 的 文件 中 了) 
选择 母 版 页 GE) 


图 8-5 “添加 新 项 "对 话 框 


【 例 8-6】 在 主题 中 建立 一 个 皮肤 文件 ,命名 为 Calendar. skin ,文件 中 包含 日 历 控 件 的 
两 种 外 观 。 


仿 - 点 认 外 观 :显示 “选择 器 ”- -名 > 
<asp:Calendar runat -"server" 
BorderColor ="Black" 
NextPrevFormat -"CustonText" 
PrevMonthText "EH" 
NextMonthText ="F H " 
SelectionMode ="DayWeekMonth" 
SelectMonthText ="$ H " 
SelectWeekText =" 整 周 " 
CellSpacing ="1" 
ShowGridLines -"True" Width -"382px" Height -"250px" 
«TodayDayStyle BackColor -"OrangeRed"/ > 
«SelectorStyle BackColor -"PaleTurquoise" /> 
«NextPrevStyle ForeColor -"Blue" / > 
«DayHeaderStyle Font -Bold "True" BackColor ="#FEEDD" /> 
«DayStyle ForeColor -"Black" / > 
«SelectedDayStyle ForeColor -"White" BackColor ="#66666" / > 
<TitleStyle ForeColor ="Brown" BackColor -"£CCCCC" /> 
<WeekendDayStyle BackColor ="#FFFCC" /> 
«OtherMonthDayStyle ForeColor -"LightGray" /> 
«/asp:Calendar > 
«& --a nu o ET 
Xasp:Calendar runat -"server" SkinID-"Simple" 
BorderColor -"Black" 
CellSpacing ="1" 
ShowGridLines -"True" Width -"382px" Height -"250px" > 
«TodayDayStyle BackColor -"OrangeRed"/ > 
XSelectorStyle BackColor -"PaleTurquoise" /> 
«NextPrevStyle ForeColor -"Blue" / > 
«DayHeaderStyle Font -Bold "True" BackColor —£FFEEDD" /> 
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<DayStyle ForeColor ="Black" / > 

<SelectedDayStyle ForeColor -"White" BackColor ="$66666" / > 

<TitleStyle ForeColor ="Brown" BackColor -"£CCCcc" /> 

<WeekendDayStyle BackColor ="#FFFCC" /> 

«OtherMonthDayStyle ForeColor -"LightGray" /> 
«/asp:Calendar > 


将 上 述 皮肤 文件 应 用 到 网 页 中 ,网 页 的 HTML 代码 如 下 : 


<%@ Page Language ="CF Theme "ER 1" 3> 
<html > 
<head runat -"server" > 
«title >Named Skins </title > 
</head > 
«body > 
<fom id "formi" runat -"server" > 
«div» 
«asp:Calendar ID -"Calendarl" runat -"server"/ ><br /> 
<br /> 
<asp:Calendar ID -"Calendar2" runat -"server" SkinID="Simple"/ > 
<br /> 
«p 半 放 思想 ,实事 求 是 ,与 时 俱 进 </p > 
</div> 
</fom> 
</body > 
</html > 


注意 : 当 为 一 个 网 页 应 用 主题 时 , 若 主题 中 包含 CSS 文件 , 则 网 页 必须 包含 < head 


runat = "server" /> 。 


8.3.4 应 用 和 禁用 主题 


1. 应 用 主题 

主题 定义 好 后 ,就 可 以 简单 快捷 地 应 用 到 站 点 中 的 各 个 网 页 中 了 。 

(1) Æ Web. config 文件 中 ,为 网 站 的 所 有 页 面 指定 主题 ,格式 如 下 : 

«system.web > 

«pages theme 一 "主题 名 "/ > 

</system.web > 

(2) 为 特定 页 面 指定 主题 。 

为 特定 页 面 指定 主题 具有 更 好 的 灵活 性 ,格式 如 下 : 

< Page Language -"Cf Theme 一 "主题 名 "%> 

使 用 Theme 属性 指定 主题 时 ,如 果 同 时 在 本 地 页 和 皮肤 文件 中 定义 了 控件 设置 , 则 度 
肤 文件 中 的 控件 设置 将 重 写本 地 页 的 控件 设置 。 


【 例 8-7】 使 用 Theme 属性 指定 主题 。 
(1) 在 “主题 1” 中 创建 一 个 StyleSheet. ess 文件 ,内 容 如 下 : 
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font -size:l4pt; 
color:red; 


) 
(2) 在 “主题 1" 中 创建 一 个 SkinFile. skin 文件 ,内 含 两 种 控件 的 外 观 。 


<asp:TextBox runat -"server" ForeColor -"Red" Text = 解放 思想 "/ > 
<asp:Button runat -"server" ForeColor -"Red" Text = 确定" /> 


(3) 将 SkinFile. skin 应 用 到 网 页 Theme. aspx 中 ,网 页 的 HTML 代码 如 下 ; 


1. «$8 Page Language -"Cf' Theme 一 主题 1"% > 

2. «html» 

3. «head runat ="server" > 

4. «itle Xil t </title> 

5. </head > 

6. «body» 

7. «form id ="forml" runat -"server" > 

8. «div» 

9. <asp:TextBox ID -"TextBox1" runat "server" ForeColor -"Blue" Text 二 解放 思想 "/ > 
10. «asp:Button ID -"Buttonl" runat -"server" ForeColor -"Blue" Text 二 确定 " / > 
nu. p FFRI </p> 

12, </div> 

13. </fom> 

14. </body> 

15. </html > 


程序 说 明 : 本 地 页 将 两 种 控件 的 前 景色 设 为 蓝 色 ,但 皮肤 文件 将 两 种 控件 的 前 景色 设 
为 红色 。 当 运行 网 页 时 ,两 种 控件 的 前 景色 均 为 红色 ,“ 科 学 发 展 观 "的 前 景色 也 为 红色 。 

除了 上 面 介绍 的 使 用 Theme 属性 指定 主题 外 ,还 可 以 使 用 styleSheetTheme 属性 指定 
主题 。 

使 用 styleSheetTheme 属性 将 主题 作为 样式 表 主 题 来 应 用 时 ,本 地 页 的 控件 设置 将 优先 
于 皮肤 文件 中 的 控件 设置 ,同时 主题 中 的 . css 文件 和 . skin 文件 会 自动 应 用 到 网 页 的 设计 视 
图 中 。 语 法 格式 如 下 : 


< Page Language -"Cf' StylesheetTheme "主题 名 "%> 
或 者 


«system.web > 
«pages styleSheetTheme 一 主题 名 "/ > 
</system.web > 


例如 ,将 例 8-7 中 Theme. aspx 网 页 中 的 第 1 行 改 为 
«&8 Page Language ="CF StylesheetTheme "ER 1" $ » 


这 时 , 若 将 网 页 切换 到 设计 视图 ,会 看 到 两 种 控件 的 前 景色 为 蓝 色 ，“ 科 学 发 展 观 ” 的 前 
景色 为 红色 ,运行 网 页 时 ,两 种 控件 和 “科学 发 展 观 ” 的 前 景色 与 设计 视图 相同 。 
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2. 禁用 主题 

禁止 某 个 控件 应 用 主题 ,可 以 通过 把 控件 的 EnableTheming 属性 设置 为 False, 把 特定 的 
控件 排除 出 主题 的 应 用 范围 来 实现 。 通 常 只 有 在 Web. config 中 使 用 Theme 属性 指定 的 主 
题 才 允许 禁用 ,使 用 styleSheetTheme 属性 指定 的 主题 是 不 能 禁用 的 。 

(1) 网 页 级 禁用 主题 : «06 Page EnableTheming =" false" % > 

(2) 控件 级 禁用 主题 : <asp: 类 名 id 2 "ID" EnableTheming = " false" / > 

某 一 网 页 禁用 主题 ,是 指 该 网 页 不 能 使 用 主题 中 的 skin 文件 ,但 仍 可 以 使 用 主题 中 的 
CSS 文件 。 
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美观 的 网 站 一 般 有 具有 “标准 ”的 页 面 布局 ,例如 左 侧 为 导航 系统 ,上 方 为 网 站 Logo, 中 间 
为 主页 ,下 面 是 版 权 信 息 等 。 有 了 统一 的 “标准 ” ,就 能 使 整个 网 站 具有 统一 的 布局 和 风格 ， 
同时 还 大 大 地 减轻 了 网 站 的 开发 工作 。 利 用 ASP. NET 2. 0 引入 的 母 版 页 ( MasgerPage ) 机 
制 ,就 可 以 轻松 地 实现 这 一 目标 。 


8.4.1 母 版 页 基础 


母 版 页 是 一 种 扩展 名 为 . master 的 ASP. NET 文件 。 母 版 页 也 是 一 个 页 面 ,可 包含 网 页 
的 所 有 项 级 元 素 ,如 html „head „body .form。 不 过 母 版 页 是 一 种 特殊 的 页 面 一 一 包含 Master 
指令 ,普通 文本 、HTML 标记、 服务 器 控件 和 ContentPlaceHolder 控件 的 预定 义 布局 。 母 版 页 
由 Master 指令 识别 ,该 指令 替换 了 用 于 . aspx 页 面 的 Page 指令 。head 元 素 必须 包含 runat 
= "server" ,运行 时 , 头 文本 用 内 容 页 的 标题 文本 来 蔡 代 。 

母 版 页 可 包含 一 个 或 多 个 ContentPlaceHolder 控件 ,ContentPlaceHolder 控件 所 占 的 空间 
用 于 存放 页 面 的 私有 部 分 ,ContentPlaceHolder 控件 内 不 能 包含 任何 控件 。 

通常 母 版 页 中 包含 的 是 页 面 的 公共 部 分 , 即 网 页 的 统一 布局 内 容 。 例 如 图 8-6 所 示 
的 “我 的 书架 "网 站 的 页 面 Index. aspx, 该 网 页 是 由 4 部 分 组 成 的 , 即 页 头 、 页 尾 ,页 面 链接 
和 内 容 页 。 经 过 分 析 可 知 , 其 中 页 头 、 页 尾 和 页 面 链接 是 网 站 中 页 面 的 公共 部 分 ; 内容 
A 是 网 站 中 的 非 公共 部 分 ,是 Index. aspx 页 面 所 独 有 的 。 结 合 母 版 页 和 内 容 页 的 相关 知 
识 可 知 ,如 果 使 用 母 版 和 内 容 页 创建 页 面 Index. aspx, 那 么 必须 创建 一 个 母 版 页 
mainMaster. master 和 一 个 内 容 页 Index. aspx。 其 中 母 版 页 包含 页 头 、 页 尾 和 页 面 链接 ,内 
容 页 则 包含 内 容 A。 

对 网 页 的 结构 分 析 好 之 后 ,就 可 以 开始 分 别 对 母 版 页 和 内 容 页 进行 设计 了 。 首 先 创建 
好 母 版 页 ,然后 再 在 母 版 页 中 创建 不 同 的 内 容 页 ,由 多 个 母 版 页 就 构成 了 一 个 统一 风格 的 网 
站 。 接 下 来 将 介绍 创建 的 具体 步 又 。 


1. 创建 母 版 页 

(1) 在 网 站 的 解决 方案 资源 管理 器 中 右 击 网 站 名 称 ,在 弹出 的 快捷 菜单 中 选择 “添加 
新 项 "命令 。 

(2) 打开 “添加 新 项 "对话 框 ,选择 “ 母 版 页 "选项 ,命名 为 mainMaster. master。 单 击 “ 添 
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图 8-6 “我 的 书架 "网 站 的 首页 


加 "按钮 就 可 以 创建 一 个 新 的 母 版 页 。 
初始 母 版 页 的 HTML 代码 如 下 : 


上 que 


«$6 Master Language ="C# AutoEventWireup -"true" CodeFile -"mainMaster.master.cs" Inherits 
-"mainMaster" % > 
<html xmlns -"http: //www.w3 .org/1999/xhtml" > 
<head runat ="server" > 
«itle > 无 标题 页 </title > 
</head > 
<body > 
<fom id ="forml" runat ="server" > 
«div» 
Xasp:contentplaceholder id -"ContentPlaceHolderl" runat -"server" > 
«/asp:contentplaceholder > 
</div> 
</fom> 
</body > 
</html > 


2. 编辑 母 版 页 

刚刚 创建 的 母 版 页 还 只 是 一 个 空 页 面 ,只 有 内 容 占 位 符 控件 。 下 面 将 对 母 版 页 进行 纺 
辑 , 为 其 添加 公共 部 分 的 布局 内 容 , 如 图 8-7 所 示 。 

(1) 将 母 版 页 中 的 contentplaceholder 控件 删 掉 。 

(2) 用 表格 重新 构建 页 面 框架 。 

(3) 添加 页 头 、 页 尾 和 页 面 链接 及 内 容 占 位 符 控件 。 

这 样 ,新 的 母 版 页 就 定义 好 了 。 但 是 ,注意 mainMaster. master 只 是 一 个 具有 同样 布局 
的 模板 而 已 ,内 容 占 位 符 处 还 没有 具体 的 内 容 。 下 一 步 就 必须 创建 内 容 页 。 有 了 内 容 页 ,加 
上 和 母 版 页 才能 够 构造 出 真正 的 显示 页 面 。 
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图 8-7 编辑 后 的 母 版 页 


8.4.0. 内容 页 基础 


有 了 母 版 页 ,就 能 够 使 用 母 版 页 创建 内 容 不 同 而 布局 相同 的 内 容 页 了 。 

通常 内 容 页 是 由 指令 和 Content 控件 组 成 的 ,普通 文本 HTML 标记 、 服 务 器 控件 都 必须 
置 于 Content 控件 之 内 ,Content 控件 内 不 能 出 现 HtmlForm 控件 ,并 且 内 容 页 与 用 户 控 件 一 
样 ,不 能 包含 网 页 的 所 有 顶级 元 素 , 如 html, head , body form。 和 运行 时 , 母 版 页 与 内 容 页 将 合 
并 生成 结果 页 。 

下 面 将 介绍 内 容 页 的 创建 方法 。 

1. 创建 内 容 页 

(1) 在 网 站 的 解决 方案 资源 管理 器 中 右 击 网 站 名 称 , 在 弹出 的 快捷 菜单 中 选择 “添加 
新 项 "命令 。 

(2) 打开 “添加 新 项 "对 话 框 ,如 图 8-8 所 示 。 在 对 话 框 中 选择 “Web 窗 体 "选项 并 命名 
为 Index. aspx, 选 中 “将 代码 放 在 单独 的 文件 中 "和 “选择 母 版 页 " 复 选 框 , 单 击 “ 添 加 "按钮 。 


Jm x 


8-8 ”添加 内 容 页 
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(3) 打开 “选择 母 版 页 ”对话 框 ,如 图 8-9 所 示 。 在 该 对 话 框 中 ,选择 母 版 页 mainmaster. 
master, 单 击 “ 添 加 ”按钮 就 可 以 创建 一 个 新 的 内 容 页 。 


图 8-9 “选择 母 版 页 "对 话 框 
也 可 以 直接 在 母 版 页 中 的 内 容 占 位 符 处 右 击 ,在 弹出 的 快捷 菜单 中 选择 “添加 内 容 页 ” 
命令 ;或 者 右 击 解决 方案 资源 管理 器 中 母 版 页 的 名 称 ,在 弹出 的 快捷 菜单 中 选择 “添加 内 容 
页 "命令 。 
2. 编辑 内 容 页 
(1) 打开 新 建 的 Index. aspx 内 容 页 ,然后 在 内 容 占 位 符 处 编辑 内 容 页 ,如 图 8-10 所 示 。 


和 
.EDPRjE- 


和 


5 2186 Wrote 
[sew uz] Hi [comes ede] 
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图 8-10 Index. aspx 内 容 页 


(2) 按 同样 的 方法 ,分 别 编辑 其 他 超 链接 内 容 页 面 jsj. aspx, wenxue. aspx .shenghuo. 
aspx „lishi. aspx 等 。 
(3) 运行 内 容 页 。 运 行 时 , 母 版 页 与 内 容 页 将 合并 生成 结果 页 ,运行 结果 如 图 8-6 
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所 示 。 
8.4.3 WEE RE UE 


MERE” ,就 是 一 个 套 一 个 ,大 的 容器 套装 小 的 容器 。 赃 套 母 版 页 就 是 指 创建 一 个 
大 母 版 页 ( 称 为 主 母 版 页 ) ,在 其 中 包含 另外 一 个 小 的 母 版 页 ( 称 为 子 母 版 页 ) 。 如 图 8-11 
所 示 为 内 套 母 版 页 的 示意 图 。 


主 母 版 页 
一 子 母 版 页 
ESETA | 
Cc 语序 设计 | | 
子 母 版 页 ck 语言 程序 设计 — TAWUR 
的 内 容 页 
comite 
ASPNETKÓSER 
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图 8-11 KERRIER 


利用 册 套 的 母 版 页 可 以 创建 组 件 化 的 母 版 页 。 例 如 ,大 型 网 站 可 能 包含 一 个 用 于 定义 
站 点 外 观 的 总 体 母 版 页 ,然后 ,不 同 的 网 站 内 容 合作 伙伴 又 可 以 定义 各 自 的 子 母 版 页 ,这些 
子 母 版 页 引用 总 体 母 版 页 ,并 相应 地 定义 合作 伙伴 的 内 容 外 观 。 

下 面 通过 一 个 实例 讲解 和 颈 套 母 版 页 的 创建 步骤 。 

(1) 创建 主 母 版 页 。 主 母 版 页 的 构建 方法 与 普通 母 版 页 的 创建 方法 一 致 。 由 于 主 母 版 
页 向 套 一 个 子 母 版 页 ,因此 必须 在 适当 的 位 置 设置 一 个 ContentPlaceHolder 控件 实现 占 位 。 
本 例 可 以 采用 前 面 已 创建 的 母 版 页 mainmaster. master 作为 主 母 版 页 。 

(2) 创建 子 母 版 页 。 子 母 版 页 的 创建 方法 和 普通 母 版 页 的 创建 方法 是 一 样 的 ,但 是 编 
辑 方法 不 同 。 因 为 子 母 版 页 的 代码 只 包括 Master 指令 和 Content 控件 两 个 部 分 ,不 包括 
html „head „body „form 等 顶级 元 素 ,同时 子 母 版 页 不 支持 设计 视图 ,所 以 ,只 能 在 源 视 图 中 进 
行 代码 编辑 。 

首先 ,为 Master 指令 添加 一 个 MasterPageFile 属性 ,设置 主 母 版 页 路 径 ,实现 主 母 版 页 和 
子 母 版 页 之 间 的 艇 套 ;然后 在 子 母 版 页 的 Content 控件 中 添加 ContentPlaceHolder 控件 作为 
内 容 页 占 位 符 。 子 母 版 页 的 HTML 代码 如 下 : 


«$0 Master Language -"'Cf' AutoEventWireup -"true" Inherits -'MasterPage" MasterPageFile = 
" ^/mainmaster.master" % > 
«asp: Content id -" Contentl" ContentPlaceholderID =" ContentPlaceHolderl" runat = 
"server" > 
«table style -"background -color :¢cff99; width: 759px; height: 498px" > 
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<tr> 
<td align ="center" style -"background -color :¢cff99" valign -"middle" > 
«nl 闻 母 版 页 </hl > 
</td> 
<td align ="center" valign -"middle" > 
<asp:contentplaceholder id -"SubContent" runat ="server" > 
</asp:contentplaceholder > 
</td> 
</tr> 
</table > 
</asp:Content > 


(3) 创建 内 容 页 。 最 后 以 子 母 版 页 为 母 版 页 创建 内 容 页 ,其 创建 方法 与 普通 内 容 页 
的 创建 方法 一 样 , 但 只 能 在 源 视图 中 进行 代码 编辑 。 由 于 内 容 页 绑 定 了 子 母 版 页 ,所 以 
代码 头 中 的 属性 MasterPageFile 必须 设置 为 子 母 版 页 的 路 径 。 例 如 ,jsj. aspx 内 容 页 的 代 
WF. 


«$8 Page Language -"Cf' MasterPageFile =" ^/subMasterl .master" Title -"Untitled Page" % > 
Xasp:Content ID ="Content1" ContentPlaceHolderID -"SubContent" runat -"server" > 
<asp:Label ID -"Labell" runat "server" Height ="24px" Text "计算 机 书目 : "> 
</asp:Label ><br> 
<asp:Label ID -"Label2" runat -"server" Text -"C 语言 程序 设计 " ></asp:Label > 


<br> 
<asp:Label ID -"Labe13" runat -"server" Text =C 揪 言 程序 设计 "></asp:Label > 
<br> 


<asp:Label ID -"Label4" runat -"server" Text -"C + 语言 程序 设计 "> 
</asp:Label ><br > 
<asp:Label ID -"Labe15" runat "server" Text -"ASP.NET 网 络 编程 " > 
</asp:Label > 

</asp:Content > 


(4) 运行 内 容 页 jsj. aspx ,运行 结 果 如 图 8-11 所 示 。 
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实 训 1 主题 的 应 用 
实 训 目的 
(1) 熟悉 主题 的 组 成 和 应 用 。 
(2) 掌握 皮肤 文件 的 创建 和 使 用 方法 。 
(3) 掌握 CSS 文件 的 创建 和 使 用 方法 。 


实 训 要 求 

(1) 创建 一 个 Web 网 站 sx08 ,并 设置 成 虚拟 目录 。 

(2) 在 网 站 中 创建 一 个 名 称 为 “主题 1” 的 主题 ,在 “主题 1” 中 创建 StyleSheet. css 文件 
和 SkinFile. skin 文件 。 

StyleSheet. css 文件 的 内 容 : 
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.one 
{ color:red; } 
.two 


{ color:blue; } 
SkinFile. skin 文件 的 内 容 : 


<asp:Label runat -"server" ForeColor -"Red" Text -"Label" SkinID -"Red"/ > 

Xasp:Button runat -'server" ForeColor ="Red" Text ="Button" SkinID -"Red"/ > 

<asp:Label runat -"server" ForeColor -"Blue" Text -"Label" SkinID -"Blue"/ > 

«asp:Button runat -'server" ForeColor -"Blue" Text -"Button" SkinID -"Blue"/ > 

(3) 在 网 站 中 添加 3 个 网 页 : sx8_1. aspx, Red. aspx 和 Blue. aspx 

(4) sx8_1. aspx 网 页 的 设计 视图 如 图 8-12 所 示 , 当 用 户 单 击 其 中 的 按钮 时 ,就 进入 相 
应 的 页 面 。 

(5) Red. aspx 网 页 的 设计 视图 如 图 8-13 所 示 ,其 文本 或 控件 的 前 景色 均 为 红色 ,Blue. 
aspx 网 页 的 设计 视图 如 图 8-14 所 示 , 其 文本 或 控件 的 前 景色 均 为 蓝 色 ,要 求 两 个 网 页 的 标 
签 和 按钮 必须 应 用 SkinFile. skin 文件 “解放 思想 , 实事求是 ,与 时 俱 进 " 必须 应 用 
StyleSheet. css 文件 。 当 用 户 单 击 “ 返 回 主页 面 " 按 钮 时 ,能 返回 sx8_1. aspx 页 面 。 


REEN 
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图 8-12 sx8 1. aspx 页 面 图 8-13 Red. aspx 页 面 图 8-14 Blue. aspx 页 面 
实 训 提示 


(1) Æ Red. aspx 和 Blue. aspx 首部 必须 加 入 如 下 代码 : 
«&8 Page Language -"Cf' StylesheetTheme =" 主 题 1" %> 


(2) 单 击 * 返 回 主页 面 "按钮 返回 sx8_1. aspx 页 面 的 实现 办 法 是 ,在 按钮 的 声明 中 加 入 
如 下 代码 : 


PostBackUrl =" ~/sx8 1.aspx" 


实 训 2 母 版 页 的 应 用 
实 训 目 的 
(1) 了 解 母 版 页 内容 页 和 相 套 母 版 页 之 间 的 关系 。 
(2) 掌握 母 版 页 的 创建 方法 。 
G) 掌握 内 容 页 的 创建 方法 。 
(4) 掌握 由 套 母 版 页 的 创建 方法 。 
KIER 
ENESA ONEAN, ED 145 1 EE 一 个 子 母 版 页 和 多 个 


191 


192% ASP. NET 网 站 开发 案例 教程 
[EE 


内 容 页 。 所 有 内 容 页 都 可 以 通过 主页 的 导航 条 进行 超 链接 访问 。 具 体操 作 方法 可 参照 本 章 
中 的 示例 。 


思考 与 练习 


一 、 填空 题 

1. ASP. NET 两 大 配置 文件 是 

2. 当 访 问 一 个 网 页 时 , ASP. NET 系统 首先 读 取 各 级 上 录 的 “文件 ,再 读 取 
文件 ,并 把 它 编译 为 . NET 框架 类 ( 即 的 子 类 ) ,最 后 执行 当前 网 页 。 

3. 一 个 主题 可 包含 多 类 文件 : 和 其 他 资源 。 

4. 一 个 CSS 文件 包含 : 和 3 类 选择 符 。 

5. 使 用 Theme 属性 指定 主题 时 ,如 果 同 时 在 本 地 页 和 皮肤 文件 中 定义 了 控件 设置 , 则 
的 控件 设置 将 重 写 的 控件 设置 。 

6. 使 用 styleSheetTheme 属性 将 主题 作为 样式 表 主 题 来 应 用 时 ， 的 控件 设置 将 

优先 于 WE, 


二 、 简 答题 

. 什么 是 样式 表 CSS? 

. 什么 是 主题 和 皮肤 ?如 何 建立 ? 

. 母 版 页 有 什么 作用 ? 

. 母 版 页 和 内 容 页 是 如 何 融合 在 一 起 的 ? 

. 柑 套 母 版 是 如 何 实现 主 母 版 页 和 子 母 版 页 之 间 的 柑 套 的 ? 又 是 如 何 实现 内 容 页 绑 
定子 母 版 页 的 ? 


tU oU 一 


ape 


当今 世界 ,网 络 已 成 为 人 们 工作 ,学习 生活 中 的 一 个 重要 组 成 部 分 。 通 过 网 络 , 人 们 可 
以 足 不 出 户 ,轻松 实现 在 家 办 公 、 远 程 学 习 、 网 上 购物 ,尤其 是 网 上 购物 已 成 为 年 轻 人 购物 的 
一 种 最 为 重要 的 方式 。 利 用 ASP. NET 技术 开发 网 上 书店 ,能 满足 人 们 方便 快捷 地 购书 的 需 
求 ,是 网 络 在 人 们 学 习 \ 生 活 中 最 实际 、 最 有 效 的 应 用 。 

本 音 将 通过 对 网 上 书店 开发 过 程 的 讲解 ,一 方面 让 学 生 对 前 面 章 节 涉及 的 ASP. NET 技 
术 有 一 个 全 面 系统 的 回顾 ,以 便 牢 固 掌握 前 面 所 学 知识 ; 另 一 方面 ,以 网 上 书店 为 实例 ,讲述 
实际 软件 项 目 设计 和 开发 的 主要 过 程 ,包括 系统 的 需求 分 析 .方案 设计 .数据库 设计 功能 实 
现 等 环节 ,使 学 生 掌 握 软件 项 目的 开发 过 程 及 方法 ,培养 学 生 实际 编程 的 能 力 。 


IRAR 
e 学 习 动态 网 站 项 目的 设计 过 程 和 方法 
。 了 解 应 用 项 目的 业务 需求 
。 掌握 ASP. NET 基本 控件 的 使 用 方法 
o 掌握 SQL Server 数据 库 设 计 和 数据 库 的 连接 
。 掌握 C# 语 言 在 实际 项 目 开发 中 的 运用 
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一 般 地 说 ,进行 软件 项 目 开 发 首先 必须 进行 系统 设计 ,和 弄 清 项 目的 性 质 、 项 目的 需求 项 
目 涉及 的 实际 业务 和 业务 流程 项 目 开 发 环境 \ 项 目 开发 目标 ,并 以 此 为 依据 ,选用 适用 的 开 
发 工具 ,系统 架构 ,进行 数据 库 设 计 功 能 设计 、 具 体 编码 ,功能 模块 测试 .系统 集成 ,系统 测 
试 、 编 把 相关 文档 。 要 严格 按照 软件 工程 的 要 求 来 开发 软件 , 切 不 可 盲目 进行 设计 ,随意 编 
码 , 以 致 项 目 失败 。 


9.1.1 系统 需求 和 功能 


网 上 书店 项 目 必须 包含 前 台 业 务 模块 和 后 台 管理 模块 。 系 统 的 使 用 对 象 有 3 类 ,一 是 
普通 游客 ,二 是 注册 用 户 ,三 是 系统 管理 员 ,一 般 均 称 为 用户 ” 。3 类 对 象 使 用 本 系统 的 权 
限 不 同 ,设计 时 ,应 针对 不 同 的 对 象 进行 权限 控制 。 设 计 过 程 要 求 界 面 清晰 美观 ,布局 合理 、 
功能 导向 明晰 且 易 理 解 、 操 作 简便 、 功 能 满足 需求 。 本 项 目的 网 站 名 称 为 网 上 书店 
Usobook , 意 为 “你 的 搜 书 网 ” 。 
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1. 网 站 公共 入 口 

网 站 公共 入 口 即 网 站 首页 ,是 呈现 给 用 户 的 第 一 个 界面 ,应 给 用 户 展 示 网 站 的 概貌 ,让 
用 户 了 解 网 站 的 性 质 .主要 功能 及 用 户 可 能 关注 的 热点 问题 ,同时 应 就 不 同类 型 用 户 进行 合 
录 控 制 。 


2. 主要 功能 模块 

(1) 用 户 注 册 管 理 : 用 户 单 击 “ 注 册 " 按钮 打开 注册 页 面 ,填写 相关 数据 ,注册 为 
Usobook 的 用 户 , 需 经 管理 员 确认 后 方 可 登录 。 如 果 用 户 忘记 登录 的 密码 ,可 以 请 求 传 回 密 
码 ,传送 的 E-mail 地 址 为 用 户 注册 的 E-mail, 

(2) 热门 图 书 快 查 : 由 管理 人 员 设 置 热门 图 书 广告 滚动 条 ,用 户 可 以 通过 单 击 查看 图 
书信 息 。 

G) 图 书 快 查 : 用 户 输入 关键 词 后 ,可 以 进行 模糊 查询 获得 相关 书 名 的 图 书 列表 ,快速 
进入 图 书 查 询 页 面 。 

(4) 深度 查询 : 在 深度 查询 页 面 中 ,用 户 可 以 通过 输入 查询 条 件 ; 书号 BA MEA .出 
版 社 .出 版 日 期 ,图书 三 级 分 类 ,综合 查询 图 书 。 

(5) 我 的 订单 : 注册 用 户 登 录 系 统 后 ,可 以 查询 处 理 购书 篮 .订单 的 信息 ,注册 用 户 从 
查 书页 面 查询 到 所 需 图 书 ,填写 拟 购书 册 数 , 单 击 购书 篮 按钮 ,加 入 到 该 用 户 的 购书 篮 中 。 
用 户 可 以 将 购书 篮 中 的 所 有 图 书 及 数量 导入 订单 中 。 购 书 篮 和 订单 明细 可 以 删改 。 

(6) 客服 中 心 : 包括 常见 问答 .投诉 建议 ,用户 资料 修改 ,用户 密码 修改 。 

(7) 联系 我 们 : 为 静态 页 面 , 主 要 介绍 网 站 的 性 质 .经 营 宗 旨 ,联系 方式 。 

(8) 后 台 管理 : 一 般 的 ,后 台 管理 可 以 采用 C/S 结构 来 编程 ,这 样 做 有 三 点 好 处 ,一 是 
安全 性 较 好 ,二 是 开发 相对 容易 ,三 是 执行 效率 较 高 。 但 是 ,作为 网 上 书店 ,管理 员 可 能 分 布 
在 不 同 的 地 理 位 置 ,必须 满足 网 上 办 公 的 需求 ,另外 图 书 业 务 可 能 分 布 在 各 省 各 地 ,要 实现 
物流 配送 ,也 必须 网 上 执行 ,因此 ,Usobook 后 台 管 理 的 大 部 分 功能 必须 采用 B/S 结构 来 实 
现 ,部 分 功能 如 订单 统计 、 报 表 打 印 采 用 C/S 结构 来 实现 ,这 部 分 功能 是 B/S 结构 的 “ 短 
板 " 。 后 台 管理 包括 注册 用 户 管理 .订单 管理 图书 管理 。 


3. 一 般 游 客 的 功能 

一 般 游客 可 以 快速 地 查询 图 书 的 详细 信息 ,可 以 进入 “客服 中 心 " 页 面 查 看 常见 问答 ， 
可 以 进入 “联系 我 们 "页 面 。 能 执行 的 功能 相对 简单 。 一 般 游客 可 注册 并 提供 审核 的 相关 
资料 (如 身份 证 复印 件 ) ,由 管理 员 审核 合格 后 转 为 注册 用 户 。 


4. 注册 用 户 的 功能 

具备 一 般 游客 的 所 有 功能 ,同时 ,可 以 将 查询 的 图 书 加 入 到 购书 篮 中 ,可 以 对 购书 篮 
中 的 图 书 进行 数量 加 减 删除 。 注 册 用 户 采用 积分 奖励 制度 , 凡 成 功 购书 (订单 完成 ) 的 
用 户 可 以 获得 与 实 付 总 价 相同 的 积分 ,每 10 个 积分 可 以 换 1 元 抵 书 价 。 用 户 将 购书 篮 中 
的 图 书 及 数量 加 入 到 订单 中 ,可 以 对 订单 进行 增删 改 操作 。 用 户 可 以 在 订单 中 设置 积分 
消费 额度 。 

用 户 可 以 维护 自己 的 注册 资料 ,可 以 修改 密码 ,如 果 忘 记 密 码 , 可 以 请 求 将 密码 发 回 注 
册 的 E-mail; 可 以 在 “客服 中 心 ”页 面 提出 建议 或 进行 投诉 。 
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5. 管理 员 的 功能 

管理 员 以 预定 的 账号 和 密码 (如 admin/usobook10y) 登录 ,直接 进入 后 台 管 理 页 面 ,可 以 
进行 注册 用 户 管理 ,包括 查询 ,修改 用 户 类 型 状态 ,积分 ,对 违规 用 户 进 行 禁用 设置 ,设置 用 
户 类 型 ;可 以 进行 订单 管理 ,包括 查询 .确认 完成 ;可 以 进行 图 书 管理 ,包括 查询 修改. 录入、 
上 传 图 书 封面 图 片 进行 三 级 图 书 分 类 设置 。 

6. 系统 配置 管理 

部 分 系统 设置 由 操作 员 直 接 在 网 站 当地 设置 ,采用 XML 文件 ,包括 热门 书 滚动 条 .最 热 
图 书 推介 .常见 问答 .数据库 连接 等 。 


9.1.2. 业务 流程 和 系统 结构 


3 类 用 户 打开 网 站 后 ,首先 可 以 查看 到 由 系统 设置 的 热门 书 广告 .随机 出 现 的 最 热 图 书 及 
介绍 ,新 书 列表 折价 书 ( 折 扣 率 和 0.8) 列 表 。 一 般 游客 可 以 在 有 限 的 权限 内 查看 图 书信 息 或 
注册 。 管 理 员 登录 后 即 进入 管理 员 的 界面 。 注 册 用 户 登 录 后 仍 停留 在 主页 ,可 以 进行 图 书 查 
if) ,用户 订 单 管理 ,包括 购书 篮 和 订单 的 查 , 增 ` 改 , 删 操 作 , 进 入 客服 中 心 进行 投诉 或 建议 、 修 
改 资料 和 密码 操作 ,用 户 查 到 所 需 图 书 时 ,可 以 按 实 际 需 求 填写 数量 并 加 入 购书 篮 中 ,如 购 节 
篮 中 已 有 该 书 , 则 数量 累加 (填写 负数 为 减 ) 。 按 角色 分 类 的 具体 流程 如 图 9-1 ~ 图 9-3 所 示 。 

登录 网 站 快速 深度 查询 
[QQ 页 aguas (E ETUR 
滚动 广告 条 


| 用 户 注册 页 面 
it 


图 9-1 一 般 游客 业务 流程 


注册 用 户 


登录 网 站 


网 站 主页 


MAIKS 
6 位 随机 验证 码 


登录 网 站 
[aan — nn He 
输入 帐号、 密码 、 
6 位 随机 验证 码 


a LY 
记录 用 户 ID 
用 户 管理 Am 
后 台 管 理 页 而 TRER f i 
图 书 管理 图 书 查询 页 面 | | 订单 管理 页 面 | 客服 中 心 页 面 
图 9-2 管理 员 业务 流程 图 9-3 ”注册 用 户 业务 流程 


9.2 数据 库 设 计 


本 系统 中 涉及 的 主要 业务 数据 有 用 户 信息 、 图 书信 息 、 订 单 头 和 订单 明细 信息 ,购书 篮 
信息 三 级 图 书 分 类 用 户 类 型 设置 ,数据 表 位 于 SQL Server 数据 库 sbkdb 中 。 常 见 问答 LR 
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动 图 书 广告 .最 热 图 书 随机 广告 分 别 位 于 qa. xml, serollad. xml , hotbook. xml 3X 3 个 XML 表 
中 。 相 关 数 据 表 的 结构 见 表 9-1 ~ 表 9-9。 
表 9-1 用 户 信息 表 Puser 


YES 
* 眉 | 类 型 (长度 ) | ax | ER & d 

ID varchar(20) | 用 户 账号 y/wv 

Pname | varchar(50) | 用 户 名 称 mn 个 人 或 单位 名 称 

Ptype char(20) 用 户 类 型 n/n/ 用 户 类 型 表 Pusertype 主键 Ptype 的 外 键 
Psecr char(20) 用 户 密码 n/n/ 加 密 的 用 户 密码 

Peount int 用 户 积分 n/n/ü 消费 时 加 减 积分 


Pregdt datetime 注册 日 期 n/n/getdate( ) | 为 用 户 注册 日 期 
Pcode char( 10) 邮政 编码 n/y/ 
Padd varchar( 80 ) 用 户 地 址 n/y/ 


Pph varchar( 50 ) 用 户 电话 n/y/ 

Pemail varchar( 50 ) E-mail n/y/ 

Pid varchar(20) | 身份 证 号 码 | mW 15 位 或 18 位 

Psex char(10) 性 别 n/n/ 男 

Pef int 有 效 性 n/n/0 0 未 审 ,1 已 审 ,2 禁用 


表 9-2 书籍 信息 表 Binfo 


字 B 类 型 (长 度 ) 含义 主键 /可 空 /默认 值 & È 
Bid varchar( 50) 书号 yv 图 书号 ,去 除 “/” 后 部 分 
btl varchar( 20 ) 一 级 分 类 n/n/ 

b2 varchar(20) 二 级 分 类 n/n/ 

b3 varchar(20) 三 级 分 类 n/n/ 

Bname varchar( 50) 书 名 n/n/ 

Bpub varchar( 50 ) 出 版 社 n/n/ 

Bauth varchar( 50 ) 作者 n/n/ 

Bdt datetime 出 版 日 期 mMy/ 

Bpri float 单价 n/y/ 

Bf float 折扣 率 vy 

Bnew int 是 否 为 新 书 n/y/0 0 新 ,1 非 

Bhot int 是 否 热门 nm0 无 效 ,未 用 

Bad varchar(1000) 书 摘 n/n/ 

num int 库存 量 ny/ 

numl int 预订 量 n/y/0 0 新 ,1 非 

num2 int n/n/0 备用 字段 

Bef int 书 有 效 性 n/n/0 9 失效 
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表 9-3 订单 批 头 信息 表 order info 


字 B 类 型 (长 度 ) 含 X 主键 /可 空 /默认 值 # È 
南 系 统 自 动 生成 ,格式 为 
OrderD | char(10) 订单 号 y/v yymmddxxx , J£ 9 位 ,前 6 位 为 年 月 
日 ,后 3 位 为 当前 序号 
wb varchar( 50 ) HP ID n/n/ 
bdt datetime 下 单 日 期 n/n/getdate( ) sa 
tpl float 总 书 价 n/n/Ü 
tp2 float 折 后 总 价 n/n/0 
prepay int 消费 积分 n/n/0 消费 时 加 减 积分 
也 int 总 册 数 n/n/0 
addr varchar( 50 ) 联系 地 址 n/n/ 
tel varchar( 50) 联系 电话 n/n/ 
contact varchar( 50 ) 联系 人 n/y/ 
state int 订单 状态 n/n/0 0 新 ,1 确认 ,2 完成 
X94 订单 明细 信息 表 order_d 
字 段 | 类 型 (长 度 ) & X | 主键 /可 空 /默认 值 备注 
id char( 10) 订单 号 y/n/ 订单 批 头 信息 表 order. info 主键 的 外 键 
bid varchar( 50) 书号 y/v id/bid 为 联合 主键 
bn varchar( 50 ) 书 名 n/n/ 
beout int 拟订 数 n/n/0 
bpri float 单价 n/n/0 
bf float 折扣 率 n/n/1 
R95 购书 篮 信息 表 bas_d 
字 B 类 型 (长 度 ) A AX 主键 /可 空 /默认 值 备注 
id char( 10) 用 户 号 y/n/ 
bid varchar( 50) 书号 y/w id/bid 为 联合 主键 
bn varchar( 50 ) $4 n/n/ 
bcout int 购书 篮 中 书 数 n/n/Ü 
bpri float 单价 n/n/0 
bf float 折扣 率 n/v/l 
表 9-6 用户 类 型 信息 表 Pusertype 
字 B 类 型 (长 度 ) 含 义 主键 /可 空 /默认 值 & i 
Ptype char(20) 用 户 类 型 ym 
表 9-7 图 书 一 级 分 类 表 Btypel 
字 B 类 型 (长 度 ) "ox 主键 /可 空 /默认 值 & i 
Btype char(20) 一 级 分 类 y/v/ 
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RIS 图 书 二 级 分 类 表 Btype2 
7 B 类 型 (长 度 ) A 义 主键 /可 空 /默认 值 & È 
Btype char(20) 二 级 分 类 ym 


表 9-9 图 书 三 级 分 类 表 Btype3 
字 ER 类 型 (长 度 ) 含 义 主键 /可 空 /默认 值 & d 
Btype char(20) 三 级 分 类 y/w/ 


9.3 文件 配置 和 数据 库 连 接 


1. Web. config 配置 
将 系统 的 数据 库 连 接 字 符 串 和 固定 的 业务 设 定 写 入 Web. config 的 appSettings 中 : 


«configuration > 
«appSettings > 
//sqlser 数据 库 连接 字符 串 
«add key -"sqlcon" value =" server =< 服 务 器 名 >; database =sbkdb; Uid =sa; password 
zx 
// 接 收 用 户 投诉 的 邮箱 
«add key -"mailTo" value =" < 收 件 电 子 邮箱 >"/ > 
«add key ="mailTob" value =" < 第 二 收 件 电子 邮 箱 >"/> 
// 邮 件 发 件 箱 
«add key -"mailFron" value =" < 发 件 电子 邮箱 >"/> 
// 发 件 箱 密码 
«add key -"mailPsd" value =" < 发 件 箱 密码 >"/> 
// 发 件 服务 器 
«add key -"mailHost" value =" < 发 件 箱 服务 器 >"/> 
// 用 户 密码 加 密 时 加 密 种 子 ,3 -6 位 数字 ,设置 后 不 可 更 改 
«add key ="secr" value ="132"/ > 
«/appSettings > 


客户 端的 Session 设置 如 下 : 
<sessionState mode -"InProc" cookieless -"true" timeout -"60"/ > 


2. 数据 库 连 接 
本 例 采用 SQL Server 数据 库 ,在 页 面 代码 开始 部 分 应 加 入 如 下 两 个 引用 : 


using System.Data.Sql; 
using System.Data.SqlClient; 


从 Web. config 文件 中 读 取 数据 库 连 接 字 符 串 sqlcon ,创建 一 个 sqlconnection 实例 作为 
公共 变量 。 
public static string sqlcon str <ConfigurationSettings.RppSettings ["sqlcon"]; 


public static SglConnection sqlcon -new SglConnection (sqlcon str); 


系统 中 还 用 到 SqlCommand , SqlDataReader , SqlDataAdapter , DataSet , GridView 等 与 数据 
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表 操作 相关 的 控件 ,关于 这 些 控件 的 用 法 ,可 参照 前 面 章节 的 内 容 。 


3. 相关 业务 设置 
(1) 常见 问答 文件 qa. xml 


<? xml version -"1.0" encoding -"UTF -8" ? > 
«questions > 
«question? 
ddf5 Via» 
«gst AP? </qst > 
«ans H </ans > 
</question > 


</questions > 


(2) 滚动 图 书 广 告 文件 scrollad. xml 


<? xml version -"1.0" encoding -"UTF -8" ? > 
«scrollads > 
<scrollad > 
<zbid 六 号 <bid> 
«alert » B4 «/alert > 
X/scrollad» 


"€ > 
(3) 最 热 图 书 随机 广告 文件 hotbook. xml 


<? xml version -"1.0" encoding -"UTF -8" ? > 
«hotbooks > 
«hotbook > 
«bid» 5 «/bid» 
«alert > 4 «/alert > 
«introduce 3 书评 «/introduce > 
«/hotbook > 


X/hotbooks > 


94 系统 实现 


系统 实现 主要 介绍 各 页 面 的 设计 .主要 控件 的 属性 和 作用 页面 事件 和 控件 事件 的 实现 
方法 和 关键 代码 ,对 于 静态 的 Label 控件 不 做 说 明 。 功 能 模块 的 实现 方法 在 代码 中 有 比较 
详细 的 注释 ,认真 阅读 代码 并 着 重 关注 注释 部 分 。 

表 9-10 是 系统 主要 页 面 和 代码 文档 表 。 

系统 中 各 页 面 的 参数 采用 客户 端的 Session[ "参数 " ] = 参数 值 和 源 页 面 Response. 
Redirect( 转向 页 面 . aspx? 参数 1 = 参数 值 1& 参数 2 = 参数 值 2…) 传 递 ,在 相应 的 页 面 配套 
Request. QueryString[ "参数 " ] 取 值 两 种 方法 。 
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页 k 


表 9-10 主要 页 面 及 代码 


代 m 


X) 能 


default. aspx 


default. aspx. cs 


主页 ,网 站 公共 信息 显示 ,用户 登录 控制 ,各 功能 模块 人 口 


regist. aspx 


regist. aspx. cs 


注册 ,用 于 新 用 户 注册 信息 和 老 用 户 修改 信息 


single book. aspx 


single book. aspx. cs 


图 书 查询 ,图书 快 查 /综合 查询 ,购书 选择 


order. aspx 


order. aspx. cs 


购书 篮 /订单 ,注册 用 户 购书 篮 和 订单 管理 


service. aspx 


service. aspx. cs 


客服 中 心 , 处 理 常见 问答 注册 用 户 投诉 建议 资料 修改 、 
密码 修改 


web_m. aspx web_m. aspx. cs 后 台 管理 ,包括 注册 用 户 管理 .订单 管理 ,书籍 管 理 
— 字符 串 加 解密 类 ,包含 在 命名 空间 MyLib 中 ,类 名 为 Meser 
(使 用 方法 见 本 节 ) 
qa. xml 常见 问答 XML 文件 
scrollad. xml 主页 滚动 广告 设置 
hotbook. xml 主页 随机 最 热 书 推介 


Session 的 主要 参数 有 如 下 几 个 。 
"Uid" ] : 注册 用 户 ID ,一 般 游客 的 值 为 空 ,管理 员 为 admin。 

(2) Session[ " Uname" ] : 注册 用 户 名 称 , 一 般 游客 的 值 为 空 ,管理 员 为 “管理 员 ”。 

(3) Session[ " Utype" ] : 用 户 类 型 ,一 般 游客 的 值 为 Guest, 管 理 员 为 adminstrator, uso, 
注册 用 户 为 MyUser。 

(4) Session[ " UEmail" ] : 注册 用 户 的 E-mail, 非 注册 用 户 为 空 。 

(5) Session[ "login ms" ] : 显示 登录 信息 ,注册 用 户 登 录 时 显示 该 用 户 名 称 (账号 ) 登 
录 时 间 , 非 注册 用 户 为 “未 登录 "。 

(6) Session[ " Bid" ] : 当前 选中 书号 或 订单 号 ,其 值 在 具体 业务 中 变化 。 

Response. Redirect 的 参数 有 如 下 几 个 。 

(1) Response. Redirect( " regist. aspx? addored =1" ) : 注册 用 户 从 客服 中 心 页 面 转向 注 
册页 面 ,addored =1 表示 老 用 户 修改 。 

(2) Response. Redirect( " single book. aspx? skey =" + TextBox4. Text) : 从 主页 面 快 查 
( 即 按钮 “ 搜 搜 ”) 传 值 转 和 人 图 书信 息 查询 页 面 , 先 读 取 skey 的 值 ,并 显示 书 名 或 作者 近似 该 
值 的 图 书信 息 ,TextBox4. Text 为 关键 词 。 

(3) Response. Redirect ( " single_book. aspx? Bid =" + GridView2. SelectedRow. Cells[ 1 ]. 
Text. ToString( ) ) : 从 主页 面 的 新 特 书 板块 查看 ,Bid 为 当前 书号 ,在 图 书 查询 页 面 读 取 Bid 
的 值 ,并 显示 书号 为 Bid 值 的 图 书信 息 。 

系统 中 使 用 了 自 定义 的 类 一 一 字符 串 加 解密 类 ,位 于 命名 空间 MyLib 中 ,类 名 为 
Mescr。 加 密 方法 为 将 不 少 于 6 位 的 源 字 符 串 1 ~6 位 的 ASCI 码 加 上 不 大 于 6 位 种 子 串 x 
xxxxx(x 为 0~9 的 数字 ) 对 应 的 值 ,其 余 加 上 10, 产 生 新 的 字符 串 , 为 加 密 字符 串 。 
采用 相反 的 方法 ,将 加 密 字符 串 进行 解密 还 原 为 源 字符 串 。 代 码 如 下 : 


(1) Session 


namespace MyLib 
{ 
// 字 符 串 加 解密 


public class Mescr 
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public string Makescr (string strl,string str2) 
//strl 为 源 字符 串 ,str2 为 加 密 种 子 字符 串 


byte []abc new byte[20] ; 
string str3 =strl; 
inti-0,j-0; 
byte dalta =10; 
for (j -0;j 20;j ++)abc[j] -0; 
for (i; i«strl.Length; i++) 
{ 
if (i <str2.Length && i «6) dalta :byte.Parse (str2 .Substring (i,1)); 
abc[i] = (byte) (byte. Parse (System. Text. Encoding. Default. GetBytes 
(strl) .GetValue (i) .ToString()) -dalta); 
) 
str3 -System. Text . Encoding.ASCII.GetString (abc) .Trim() ; 
return str3.Trim(); // 返 回 加 密 字符 串 
} 
public string Desscr (string strl, string str2) 
//strl 为 加 密 后 的 字符 串 ,str2 为 加 密 种 子 字符 串 
| 
byte[]abc -new byte[20] ; 
string str3 -strl; 
inti-0,j-0; 
byte dalta 10; 
for (jæ; j 20; j ++) abc[j] æ; 
for (1-0; i<strl.Length; i++) 
{ 
if (i <str2 .Length && i <6) dalta -byte.Parse (str2 .Substring (i,1)); 
abc [i] =(byte) (byte. Parse (System. Text. Encoding. Default.GetBytes (strl). 
GetValue (i) .ToString ()) +dalta) ; 
} 
Str3 -System.Text .Encoding.ASCII.GetString (abc) .Trim(); 
return str3.Trim(); // 返 回 还 原 字符 串 


} 


9.4.1. 网 站 主页 


系统 主页 面 default. apsx 是 系统 各 业务 功能 页 面 的 入口, 图 94 是 呈现 给 用 户 的 主 
页 面 。 
考虑 到 客户 端 显示 器 分 辩 率 不 同 ,项 目 要求 满 足 1024 x 768 以 上 的 分 辩 率 ,所 以 
应 使 页 面 处 于 中 间 位 置 ,保证 页 面 的 宽度 不 超过 1024px, 在 此 系统 中 将 宽度 控制 
为 980px。 

(1) 页 头 部 分 : 包括 一 个 Image 控件 一 个 Menu 控件 ,两 个 Label 控件 .一 个 TextBox 控 
件 和 一 个 Button 控件 ,属性 设置 和 作用 见 表 9-11。 
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lo-o-3id46 P e23-$»5-LJ E 
TA O max Dar genos I RESNI 
E 你 的 搜 书 网 [p m = 
"e | ie 
到 | 
ES, EYES. cnson iB 
图 94 网 站 首页 
表 9-11 主页 页 头 控件 
控件 ID 主要 属性 作 用 
JImagel ImageUrl; -/image/imgl. bmp 网 站 Logo, 可 替换 
Orientation; Horizontal 
Columns; 
0 Tex; 首页 ;Value: 首页 ; NavigateUrl; ~ /default. aspx 
1 Text: 深度 查询 ;Value: 深度 查询 ; NavigateUrl ; 
~/single_book. aspx 
Menul 2 Text; 我 的 订单 ;Value: 我 的 订单 ;NavigateUrl: 主 菜单 
~ / order. aspx 
3 Text 客服 中 心 ;Value: 客服 中 心 ;NavigateUrl: 
~ /service. aspx 
4 Text: 联系 我 们 ;Value: KARI]; NavigateUrl ; 
~ /aboutus. aspx 
Label6 Text; 关键 词 显示 
用 户 未 登录 或 登录 不 成 功 显 
Label2 Text; 未 登录 示 “ 未 登录 ” ,用户 登录 后 显 
示 用 户 名 (账号 ) 和 登录 时 间 
TextBox4 | Text: null;AutoPostBack: False 快速 查询 关键 词 
Buttonl Text; 848 快速 查询 按键 


(2) 页 中 左 侧 : 包括 用 户 登 录 .随机 验证 码 图 形 显示 、 随 机 最 热 图 书 介绍 ,控件 的 主要 
属性 和 作用 见 表 9-12。 


表 9-12 ”页 中 左 侧 控件 


Eo 主要 属性 作 用 
用 户 账号 , 回 车 或 失去 焦点 
TextBoxl Text: null; AutoPostBack: True 时 ,系统 生成 6 位 随机 十 六 
进 制 码 ,以 图 示 方 式 显示 
TextBox2 Text; null; AutoPostBack: False 用 户 密码 
TextBox3 Text: null; AutoPostBack: Fasle 6 位 随机 十 六 进 制 验证 码 
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续 表 
控 件 ID 主要 属性 作 用 
TextBox5 Text: null; AutoPostBack:; False; Visible; False ed 6 位 随机 十 六 进 制 验 
Jmage2 ~ Image7 | ImageUrl; null; Visible: False e RM 十 六 进 制 验证 
ErrorMessage: $è 证 码 错 !; ControlToCompare: 
ComValial TextBorS ; ControlToValidte:; TextBox3 o BUT | 比较 验证 控件 
Button2 Text: 登录 用 户 登录 
Button3 Text: 注册 用 户 注册 
Button6 Text: 忘记 密码 d ,输入 用 户 账号 后 
Tmage8 ImageUd ; < 随机 书 封 图 像 > ;Visible: True 随机 最 热 书 书 封 
TextBox6 Text: null;AutoPostBack: False; TextMode ; MultiLine 最 热 书 介 绍 


(3) 页 中 右 侧 : 包括 热门 图 书 介绍 ,新书 推介 特价 书 列表 ,控件 的 主要 属性 和 作用 见 


表 9-13。 
表 9-13 页 中 右 侧 控件 
控 件 ID 主要 属性 作 n 
< marquee id = "hotscr" runat =" server" direction = AS h P ma 
"left" height =" 80" scrolldelay = " 150" style = RRR 告 条 ,内 容 由 系统 
hotscr 5 3 k 读 取 scrollad. xml 文件 保存 在 字 
left :Opx; position ; relative ; top :Opx; width ; ER abe 中 
723px;" > <% =abc % > </marquee > ^ 
Button Text; 新 书 ;Enable: True 显示 新 录入 的 图 书 列表 
ButtonS Text; 特价 书 ;Enable: False 显示 折扣 率 <0.8 的 图 书 列表 
EMEN ConnectString; < 由 Button4/5 确定 > 
SqlDataSourcel DatsSourceModo- Daisset gridviewl/2 的 数据 源 
Caption; 新 书 推介 ; DataSourceID : SqlDataSourcel ; 
AllowPaging: True; AutoGenerateColumns: False; 
c Du Bid; PageSize: 5 新 gu 4 
0 headtext; 封面 ;Visible: False an PE EE TEE A af 
GridViewl 1 headtext; 书号 ;Datafield: Bid xm E rail - o^ a m 
2 headtext; 书 名 ;Datafield: Bname pep o F 
3 headtext; 出 版 社 ;Datafield: Bpub [is n 
4 headtext; 作者 ;Datafield: Bauth Hen 
5  headtext; 单价 ;Datafield: Bpri 
6  headtext; 选择 ;Datafield: Bid CommandField 
Caption; 特价 书 ;DataSourceID :SqlDataSourcel ; 
AllowPaging: True; AutoGenerateColumns; False; 
c d Bid;PageSize: 5 特价 书 列表 
0  headtext; 封面 ;Visible: False Y 2X adeat ox fo 
GridView2 1 headtext; 书号 ;Datafield: Bid RUD "phe e is ü 
2 headtext; 书 名 ;Datafield: Bname 行 选择 产生 id " 2 isadi 
3 headtext; 原 书 价 ;Datafield: Bpri 5 ES TNI 
4 headtext; 折扣 率 ;Datafield: Bf E 
5 headtext; 节省 额 ;Visible:False 
6  headtext: 选择 ;Datafield: Bid CommandField 
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(4) 页 下 侧 : 显示 版 权 、 网 络 许 可 信息 。 
主要 代码 如 下 : 
(1) 公共 变量 


public static string sqlcon str -ConfigurationSettings .AppSettings ["sqlcon"]; 
public static SqlConnection sqlcon -new SqlConnection (sqlcon str); 


public static string abc -""; // 移 动 广告 条 变量 
string secr -ConfigurationSettings.AppSettings ["secr"] .Trim() ; // 密 码 加 密 种 子 
Mescr msc new Mescr (); // 创 建 一 个 字符 串 加 密 的 对 象 


(2) Page_Load( ) 事 件 


protected void Page Load (object sender, EventArgs e) 
{ 


DataSet dst -new DataSet () ; // 存 放水 平 广告 条 数据 
DataSet dst1 -new DataSet () ; // 存 放 最 热 随 机 推介 数据 
DataTable dtt,dttl; 

string Bid-"",alt-""; 

Random rr new Random (10) ; 

int kran; // 随 机 数 


SqlDataAdapter dtad -new SqlDataAdapter () 7 
SqlDataSourcel.ConnectionString -sqlcon str; 
if (!Page.IsPostBack) 
{ 
// 关 闭 登 录 验 证 码 图形 Image2 ~Image7 
Jmage2 .Visible =false; 
… < 此 处 省 略 > 
Jmage7.Visible -false; 
Button4 Click (sender, e); 
) 
if (sqlcon.State —-ConnectionState.Closed) sqlcon.Open(); 
// 读 入 热门 书籍 水 平 滚动 条 
dst.ReadXml (Server .MapPath ("xml /scrollad.xml")); 
dtt -dst .Tables[0]; 
abc-""; 
for (int i =1;i «-dtt.Rows.Count;i ++) 
t 
Bid-dtt.Rows[i-1].ItemArray[0].ToStringO; //M&Mk i -1 TAA 1 列 数据 
alt -dtt.Rows[i -1].ItemArray[1].ToString(); 
abc +=" «a href -single book.aspx?Bid =" 4Bid +" >" +" <img src —image/book/" + 
Bid +".jpg" +" style =\x22WIDTH: 52px; HEIGHT: 71px W22 alt =\x22" +alt + 
"\x22/ ></a>"; 
} 
abc+= 热门 图 书 介绍 "; 
// 随 机 读 人 最 热门 书籍 介绍 
dstl .ReadXml (Server .MapPath ("xml /hotbook. xml") ) ; 
dtt1 -dst1.Tables [0] ; 
alt="; 
for (int j 0;j <=rr Next (0, DateTime .Now. Second) ;j ++) 
kran =rr .Next (0, dtt1 .Rows .Count) ; 
Bid-dttl.Rows[kran].ItemArray[0].ToString); // 提 取 守 工行 的 第 工 列 数据 


} 
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alt -dttl.Rows [kran] . ItemArray [2] .ToString () ; 


Image8 . ImageUr1 -"image/book/" Bid ?" . jpg"; 
Image8 .AlternateText -dttl.Rows [kran] . ItemArray [1] .ToString(); 
TextBox6 .Text -alt; 


(3) 快速 搜 书 Buttonl_Click( ) 事 件 


protected void Buttonl Click (object sender, EventArgs e) 


{ 


} 


if (TextBox4.Text.Length >0) Response.Redirect ("single book.aspx? skey =" +TextBox4 . 


Text); 


变量 skey 传递 搜 书 关键 词 ,可 以 查找 类 似 的 作者 和 书 名 。 
(4) TextBoxl_TextChanged( ) 事 件 
当 用 户 账号 文本 框 失去 焦点 时 ,产生 6 位 十 六 进 制 随机 码 , 并 在 Image2 ~ Image? 中 显 


示 对 应 的 图 像 。 


protected void TextBoxl TextChanged (object sender, EventArgs e) 


{ 


string strrnd-""; 

string strpic-""; 

string strsc-""; 

Random ran -new Random () ; 
int i,krnd; 
for(id;i«-6;i44) 


{ 


krnd =ran.Next (0,16) ; 
Switch (krnd) 


t 


} 


//10 A,11 B,12 C,13 D,14 E,15 F 
case 10: 
strrnd +="A"; 
strsc ='A"; 
break; 
… < 此 处 省 上 > 
case 15: 
strrnd t-"F"; 
strsc-"F"; 
break; 
default: 
strsc -krnd.ToString(); 
strrnd *-krnd.ToString(); 
break; 


switch(i) 


{ 


// 显 示 对 应 的 图 片 文件 
case 1: 
Image2 .ImageUrl =" ~/image/ 认 证 图 片 /na" +strsc +" bmp"; 
Image2.Visible true; 
break; 
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} 


… < 此 处 省 略 > 
} 
} 
TextBox5 .Text =strrnd; 


(5) 用 户 登 录 Button2_Click( ) 事 件 

用 户 登录 时 ,数据 表 Puser 中 的 密码 是 按 系 统 设 定 规则 加 密 的 ,必须 对 TextBox2. Text 进 
行 加 密 后 方 可 比较 ,系统 已 经 编写 了 一 个 字符 串 加 密 类 ,用 于 对 字符 串 加 解密 。 在 代码 文档 
头 引 入 using MyLib。 使 用 时 定义 一 个 字符 串 加 解密 实例 Meser mse = new Mescr( ) 。 


protected void Button2 Click (object sender, EventArgs e) 


{ 


string login id,ps; 

SqlCormand sqlsel new SqlCommand () ; 

SqlDataReader drr; 

Boolean exst -false; 

string uname, uemail; 

string upsd -TextBox2.Text; 

int Pef; 

Pef -0; 

login id-""; 

uname -""; 

uemail-""; 

Session |["Utype"] -"Guest"; 

// 管 理 员 登录 后 直接 进入 后 台 管理 页 面 

if (ConValidl .IsValidgg (TextBoxl .Text —-"admin") && (TextBox2 .Text =="usobook10y") ) 

{ 
Session["Uid"] -"admin"; 
Session["Uname"] "EHR"; 
Session["Utype"] -"Adminstrator uso"; 
Response.Redirect ("web m.aspx") ; 
return; 


} 

// 非 管理 员 , 需 先 判断 用 户 的 有 效 性 ,0 表示 未 审核 ,1 表示 可 用 ,9 表示 禁用 

sqlsel .Connection =sqlcon; 

Sqlsel.CommandText ="select * from Puser where lower (id) -'" 4TextBoxl.Text.ToLower () 
+" 'and psecr -' " 4msc.Makescr (upsd, secr) +" ' "; 


if (ConValidl.IsValid) 
{ 
if (sqlcon.State ==ConnectionState.Closed) sqlcon.Open (); 
drr =sqlsel .ExecuteReader () ; 
while (drr.Read()) 
t 
exst rue; 
uname -drr ["Pname"] .ToString(); 
uemail -drr ["Pemail"].ToString(); 
ps =drr ["Psex"] .ToString() ; 
Pef -Int32 . Parse (drr ["Pef"] .ToString()); 


} 
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if(ps==" 男 ") 
login id 下 欢迎 您 "+drr["Pname"] .Tostring() +" (" +drr ["id"] . 
ToString () 六 ) 先 生 . 今 天 是 " 4DateTime.Now. ToShortDateString () ; 
else 
login id "Xlll fit" +drr ["Pname"] .ToString () +" (" +drr ["id"] . 
ToString () 六 ) 女 士 .今天 是 " 4DateTime.Now. ToShortDateString () ; 
} 
drr.Close(); 
{ 
if (exst) 
t 
if (Pef ==) 
t 
Llabel2.Text-login id; 
Session ["Uid"] -TextBoxl Text; 
Session ["Uname"] -uname; 
Session |["Utype"] -"MyUser"; 
Session ["UFmail"] -uemail; 
} 
证 (Pef=-0) Label2.Text "未 通过 审核 ,系统 会 在 一 个 工作 日 内 予以 审核 "; 
if (Pef ==) Label2.Text "该 用 户 因 违 反 相关 约定 为 禁用 "; 


else 
{ Labe12.Text =" 用 户 未 登录 "7 
} 

} 


} 
Session["login ms"] =Label2 .Text; // 在 后 续 页 面 中 显示 登录 信息 


(6) 注册 Button3_Click( ) 事 件 

属性 PostBackUrl; ~ /regist. aspx, 单 击 “ 注 册 ” 按 钮 进入 注册 页 面 。 

(7) 忘记 密码 Button6_Click( ) 事 件 

当 用 户 忘 记 密 码 时 , 单 击 Button6 ,系统 将 密码 发 送 到 用 户 注册 时 的 电子 邮箱 。 下 面 程 
序 使 用 了 邮件 收发 控件 ,必须 在 文档 头 部 引用 命令 空间 System. Net. Mail, 


protected void Button6 Click (object sender, EventArgs e) 


I 


if (TextBoxl.Text.Length =-0) ( showmessage ("请 输入 用 户 账号 ! ") ; return; } 

SqlCommand exst com-new SqlCormand ("select * from Puser where id -'" 4TextBoxl.Text + 
"'",sqlcon); 

SqlDataReader dr; 

string eml =""; // 用 户 E-mail 
string scr ="; 

if (sqlcon.State --ConnectionState.Closed) sqlcon.Open(); 
dr-exst com.ExecuteReader () ; 

while (dr.Read()) 

{ 


scr msc .Desscr (dr ["Psecr"] .ToString(), secr) ; 
eml -dr ["Pemail"].ToString(); 
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} 

dr.Close(); 

if (scr--"") ( shownessage (" 该 账号 用 户 不 存在 ") ; return; } 
SendMailUseZj (TextBoxl .Text, scr, eml) ; 


public void SendMailUseZj (string uid, string scr,string eml) 

{ 
// 创 建 一 个 邮件 对 象 
System.Net .Mail.MailMessage msg new System.Net .Mail .MailMessage (); 
string mailTo -eml; 
string mailFrom -ConfigurationSettings.AppSettings ["mailFrom"]; 
string Psd -ConfigurationSettings.AppSettings ["mailPsd"]; 
string mailHost -ConfigurationSettings.AppSettings ["mailHost"]; 
// 指 定 收 件 人 ,可 以 发 送 给 多 人 
msg. To. Add (mailTo) ; 
// 指 定 发 件 邮箱 
msg.From new MailAddress (mailFrom, "jyc", System. Text . Encoding . UTF8) ; 
/* Lii 3 个 参数 分 别 是 发 件 人 地 址 (可 以 随便 写 ) ,发 件 人 姓名 ,编码 * / 
msg. Subject "HP RT"; // 邮 件 标题 
msg.SubjectEncoding-System.Text.Encoding.UTF8; 。”// 邮 件 标题 编码 
msg.Body = 您 在 Usobook 注册 的 账号 :" tuid +" Ve 密码 是 :" +scr; 。”// 邮 件 内 容 
msg.Body +=" v" +DateTime.Now.ToString (); 


msg. BodyEncoding -System. Text . Encoding . UTF8 ; // 邮 件 内 容 编码 
msg.IsBodyHtml -false; // 是 否 是 HM 邮件 
msg.Priority -MailPriority.High; // 邮 件 优先 级 


SmtpClient client new SmtpClient (); 
client.Credentials new System.Net.NetworkCredential (mailFrom, Psd) ; 
// 发 件 邮箱 ( 非 客 户 邮箱 ) 和 密码 
client.Host -mailHost; 
object userState -msg; 
try 
{ 
client.Send (msg) ; 
Page.ClientScript.RegisterStartupScript (this.GetType () , "", "alert (' 发 送 成 
31); ",true); 
$ 
catch (System.Net .Mail.SmtpException ex) 
| 
Page.ClientScript.RegisterStartupScript (this.GetType () , "", "alert (" 发 送 邮件 
it); ", true); 


} 
(8) 新 书 列表 Button4_Click( ) 事 件 


protected void Button4 Click (object sender, EventArgs e) 
{ 
SqlDataSourcel.SelectCommand-"select * from Binfo where Bnew-0"7 
GridViewl.Visible «rue; 
GridView2 .Visible -false; 
Button5 .Enabled rue; 
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Button4 Enabled -false; 
) 


(9) 特价 书 列 表 Button, Click ( ) 事 件 


protected void Button5 Click (object sender, EventArgs e) 


| 
SqlDataSourcel.SelectCommand -"select * from Binfo where Bf «-0.8"; 


GridView2.Visible «rue; 
GridViewl.Visible -false; 
Button4 .Enabled -true; 
Button5 .Enabled -false; 

} 


9.4.2 用 户 注册 


用 户 可 以 直接 从 主页 进入 注册 页 面 ,进入 时 各 输入 框 清空 。 如 果 登 录 的 是 注册 用 户 , 也 
可 以 从 客服 中 心 页 面 进入 注册 页 面 修改 用 户 资料 ,图 9-5 为 用 户 注册 设计 页 面 。 


h 你 的 搜 书 网 


g 
puews F PR | GP 
DR PWSETEMENS ParmEl Pr — 
paraw] f pem] p ——— 
p Ree if $opemp 

o i 
本 RE 同村 7 下 可 了 东 了 入 prm] p— — — — — — 
jan : 
Pr | 了 xj 


册 协 议 : 司 "m 

、 会 员 必须 遵守 国家 相关 法 令 法 规 BERI Ent] 
DERRHBAM, BACREREUERAX i 

、 会 员 在 订单 生效 (发 书 ) 后 不 得 修改 ] 
、 本 网 店 在 有 了 配送 区 域 免 收 递送 细 


到 


Fomes 。 个 不 同意 本 协议 


图 9-5 用 户 注册 设计 页 面 


页 面 控件 的 主要 属性 和 作用 见 表 9-14。 
表 9%-14 页面 控件 的 主要 属性 和 作用 


控件 mD 主要 属性 作 用 
TextBoxl Enable: 新 注册 时 为 True ,修改 时 为 False 用 户 账 号 
Buttonl Text: 是 否 同名 a a 

in 显示 是 否 存在 
ext: 5 t$ Visible: se 
Labels Text: 账号 已 存在 ,请 …;Visible: Fal 同名 账号 
TextBox2 用 户 名 称 
TextBox3 TextMode:Password 用 户 密码 
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i (om 主要 属性 作 用 
TextBox4 TextMode ; Password 确认 用 户 密 码 
. ErrorMessage: 两 次 密码 不 同 !; ControlToCompare : 
a validated TextBox3 ; ControlToValidte: TextBox4 比较 验证 控件 
RegularExpressionValidator2 ie 6 ~ 12 位 数字 或 字符 ; ControlToCo “| 正则 验证 控件 
DropDownListl Items 在 页 面 装载 时 从 表 Pusertype i A. 用 户 类 型 
TextBox5 邮政 编码 
TextBox6 用 户 地 址 
TextBox7 联系 电话 
TextBox8 E-mail 
ErrorMessage: E-mail 格式 错误 ; ControlToCompare: 
RegularExpressionValidatorl TextBox8 ; ValidationExpression; Ww  ([ - +. '] W + ) | E-mail 验证 
*GeWwe([-.]Wwe)*VWws([-.]w*)* 

TextBox9 身份 证 号 码 

本 . ErrorMessage: 15 位 或 18 位 数字 ; ControlToCompare: — 
RegalarExpressionValidator — r.p o y lidationExpression: 17] [MIX] MISI 身份 证 验证 
RadioButtonListl Items; 0 女 ;1 男 性 别 选 择 
RadioButtonList2 Items: 0 同意 ;1 不 同意 (checked) 是 否 同意 协议 
Button2 Text: 提交 ;Enable: Fasle 提交 注册 
Button3 Text; 重新 输入 用 户 注册 
Labell4 操作 提示 


由 于 事件 中 使 用 密码 读 取 和 写 和 数据库 ,必须 对 密码 进行 加 解密 ,所 以 在 文件 头 部 应 引 
用 字符 串 加 密 库 文件 (using MyLib) ,并 创建 一 个 字符 串 加 解密 的 实例 。 主 要 代码 如 下 : 


public partial class regist:System.Web.UI.Page 
(1) 公共 变量 


// 获 得 数据 库 连 接 字符 串 

public static string sqlcon str -ConfigurationSettings .AppSettings ["sqlcon"]; 

public static SglConnection sqlcon -new SqlConnection (sqlcon str); 

public static string addored; // 标 识 用 户 处 于 修改 还 是 新 增 状态 ,1 代表 修改 ,0 代表 新 增 
string secr -ConfigurationSettings.AppSettings ["secr"] ; // 密 码 加 密 种 子 

//Mescr 是 MyLib 库 的 一 个 类 ,处 理 字符 串 加 解密 


Mescr msc -new Mescr (); 
(2) Page Load( ) 事件 


protected void Page Load(object sender, EventArgs e) 
| 
SqlConmand sqlcom new SqlCommand () ; 
SqlDataReader dr; 
Sqlcom.Connection -sqlcon; 
Sglcom.CommandText ="select distinct * from Pusertype"; 
string psd "11111111"; 
if (sqlcon.State --ConnectionState.Closed) sqlcon.Open(); 
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if (!Page.IsPostBack) 


{ 


// 为 "用 户 类 型 "下 拉 列 表 框 添加 Pusertype 数据 
dr =sqlcom.ExecuteReader () ; 
DropDownListl.Items.Clear(); 
while (dr.Read()) 
i 
if (! ((dr["Ptype"] .ToString() .Trim()) ==" 管 理 员 ")) 
DropDownListi.Items.Add (dr ["Ptype"] .Tostring()); 
) 
dr.Close(); 
// 判 断 是 来 自主 页 注册 还 是 来 自 客服 中 心 "修改 用 户 资料 " 
// 当 来 自 客服 中 心 时 Response.Redirect ("regi st .aspx?addored =") , Bl £I] addored 村 
try 
{ addored -Request .QueryString["addored"] .ToString(); } 
catch [addored -"0"; ) 
// 来 自 客服 中 心 , 导 入 用 户 资料 
if (addored --"1") 
f 
Sqlcom.CommandText ="select + from Puser where ID='" +Session["uid"] +"'"; 
dr =sqlcom. ExecuteReader () ; 
while (dr.Read()) 
{ 
Button2 .Enabled =true; 
TextBoxl.Text =dr [0] .ToString () ; 
TextBox1 .Enabled =false; 
TextBox2 .Text -dr [1] .ToString () ; 
DropDownList1 .Text =dr [2] .ToString () ; 
// 此 时 密码 不 能 修改 ,要 修改 密码 ,应 在 客服 中 心 页 面 的 "修改 用 户 密码 "面板 处 
修改 
TextBox3 .Enabled =false; 
TextBox4 .Enabled =false; 
TextBox5.Text =dr [6] .ToString(); 
TextBox6 .Text -dr ["padd"] .ToString () ; 
TextBox7 . Text -dr ["pph"] .ToString () ; 
TextBox8 .Text -dr ["Pemail"].ToString(); 
TextBox9.Text -dr ["pid"].ToString(); 
RadioButtonListl.SelectedValue =dr ["psex"] .ToString (); 
RadioButtonList2 Enabled -false; 
Button2.Text "AHE"; 
Button2.Enabled true; 
psd msc .Desscr (dr [3] .ToString(), secr); 


} 
dr.Close(); 
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(3) 判断 是 否 同名 Buttonl_Click( ) 


lini 


FF 


protected void Buttonl Click (object sender, EventArgs e) 
{ 
SqlCommand sqlsel new SqlConmand () ; 
SqlDataReader drr; 
Boolean exst -false; 
sqlsel .Connection -sqlcon; 
Sqlsel.CommandText -"select * from Puser where lower (id) -'" 4TextBox1 . Text . ToLower () 
pu 
drr -sqlsel.ExecuteReader () ; 
if (sqlcon.State --ConnectionState.Closed) sqlcon.Open(); 
if (drr.Read()) ( exst true; } 
if (exst) 
i 
Label5.Visible true; 
} 
else 
{ Label5.Visible =false; } 
drr.Close(); 
) 


(4) 是 否 同意 协议 选择 RadioButtonList2_SelectedIndexChanged( ) 事件 


protected void RadioButtonList2 SelectedIndexChanged (object sender, EventArgs e) 
{ 
if (addored --"1") return; // 当 判断 处 于 修改 状态 时 ,忽略 同意 协议 
RadioButtonList2 .RutoPostBack true; 
if (this.RadioButtonList2.SelectedIndex --0) Button2 .Enabled true; 
else Button2 .Enabled -false; 
) 


(5) 提交 保存 Button2. Click ( ) 事 件 


protected void Button2 Click (object sender, EventArgs e) 
{ 
SqlConmand ins_com new SqlConmand () 7 
SqlTransaction trans =sqlcon .BeginTransaction () ; 
string ins str-""; 
if (TextBoxl.Text ==" || TextBox2.Text ==" || TextBox3.Text ==" || TextBox5.Text == 
"" || TextBox6 Text ==" || TextBox7. Text ==" || TextBox8. Text ==" || TextBox9.Text == 


m) 


{ 


shownessage ("注册 操作 :所 有 信息 均 不 能 为 空 ") ; 
return; 
} 
/ /DropDownListl.Text =""; 
// 新 用 户 注册 
if (addored --"0") 
{ 
ins str-"insert into Puser values ('"; 
ins str *-TextBoxl.Text.ToLower () +"', '" £TextBox2. Text 4" ', '" 4DropDownListl. 
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SelectedValue.ToString() ?"','"; 

ins str -msc.Makescr (T extBox3.T ext, secr) +"',0, '" 4DateTime. Now. ToString () + 
m! '" ATextBox5 Text. +"', '" ATextBox6 Text 4" , '"; 

ins str + =TextBox7. Text +"', '" +TextBox8. Text +"', '" 4TextBox9. Text 4" ', '" + 
RadioButtonListl.SelectedValue.ToString() +"',0"; 


) 

// 老 用 户 修改 
if (addored= 

{ 


1") 


ins str -"update Puser set Pname -'" TextBox2 .Text +"',"; 
ins str *-"Ptype -'" £DropDownListl.SelectedValue. ToString () ?" ', Pcode ='" + 
TextBox5.Text +"',"; 
ins str *-"Padd ='" +TextBox6. Text 4" ', Pph ="'" 4TextBox7. Text +"', Pemail —'" + 
TextBox8 .Text +""', Pid-'" +TextBox9 Text +"',"; 
ins str -"Psex-'" tRadioButtonListl.SelectedValue.ToString () +"' where id -'" + 
TextBoxl .Text +"'"; 
} 
ins com.Connection =sqlcon; 
ins com.CommandText =ins str; 
ins com.Transaction trans; 


try 
{ 
ins com.ExecuteNonQuery () ; 
Labell4.ForeColor -System.Drawing.Color.Yellow; 
Labell4.Text "注册 操作 :成 功 "; 
shownessage ("注册 操作 :成 功 "); 
trans.Conmit () ; 
} 
catch 
{ 
Label14 .ForeColor -System.Drawing.Color.Red; 
Label14.Text "注册 操作 :失败 "; 
showmessage ("注册 操作 :失败 "); 
trans.Rollback|(); 
} 
finally 
{ 
sqlcon.Close (); 


) 


//showmessage () 函数 用 于 显示 提示 信息 
protected void showmessage (string str) 


{ 
Page.ClientScript.RegisterStartupScript (this.GetType (),"","alert ('" +str +"');", 
true); 


9.4.3 图 书 查询 
图 书 查询 页 面 Single_book. aspx 接受 一 般 游客 和 注册 用 户 进行 快速 查询 和 深度 查询 ,用 
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户 可 以 进行 简单 查询 ,也 可 以 进行 综合 查询 。 图 9-6 是 图 书 查 询 页 面 ,也 是 注册 用 户 选择 图 


书 并 加 入 购书 篮 中 的 页 面 。 
LU 
k 你 的 搜 书 网 ger amende Iaa | + 
村 [D PF -x:o98k 
s [————— a oa dietis 
tE E — —5 du 清华 大 学 出 版 福 
dat: EFS 
WRES 9E CWUHUCENETEJUSSS. 
HIRERE: 2002-1060 00 
c m I LT E— 
2 ku pans 
ae RO al * nis po 
zus [TR r] sara nane [COE RR 
të ME: em ERSPREEGJCKS TALAREN E) 
v» 2 RE 
vu st 
mo ck 
ET 
Des BFAS Een EE 司 
ER 
mers TI 
Mao TAa g z 
图 96 图 书 查询 页 面 


页 面 结构 分 为 上 、 下 左 、 下 右 3 部 分 。 

(1) 上 部 : 设置 一 个 菜单 ,可 以 返回 首页 或 转向 “我 的 订单 "页 面 ,可 以 输入 关键 词 快速 
查 书 ,标签 Label 显示 用 户 登录 信息 。 

(2) FERD: 设置 图 书 查询 条 件 和 查询 结果 的 列表 。 单 击 可 查看 图 书 详细 信息 。 

(3) 下 右 部 分 : 显示 图 书 详细 信息 ,包括 书 封 图 像 .书号 , 书 名 出 版 社 , 作 者 、 三 级 分 
类 出 版 日 期 .可 购 量 ( 实 存量 -确认 订单 的 拟 购 量 总 和 ) .单价 .折扣 率 、 书 摘 ,用 户 待 选 入 
购书 篮 的 量 和 加 入 购书 篮 中 的 执行 按钮 。 其 中 书 封 图 像 由 管理 员 在 录入 该 书 时 上 传 至 服务 
器 /image/book 目录 中 。 

表 9-15 为 图 书 查询 页 面 的 主要 控件 的 属性 和 作用 。 


表 9-15 ”图书 查询 页 面 的 主要 控件 属性 和 作用 


控件 人 D 主要 属性 作 用 
上 部 控件 
Menul 上 部 菜单 
TextBox4 快 查 输入 框 
Label2 Text: < 登录 信息 > 用 户 登 录 
Buttonl Text: 搜 搜 快速 搜 书 
下 左 侧 控件 
TextBox7 ~ TextBox10 图 书信 息 
RegularExpression posean dela bud 年 ) -| 正则 验证 控件 
Validator Aue — i 日 期 段 为 年 -年 
DropDownList5 ~ Ttems 在 页 对 从 表 Btypel ~ B E 
和 ep |- arg 
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续 表 
控件 人 D 主要 属性 作 用 
Button6 Text: 详细 查询 执行 综合 查询 
GridViewl 查询 结果 简明 图 书 列表 图 书 列表 ,选择 时 显示 图 书 详细 信息 
下 右 侧 控件 
Labell ,Label2 .Label3 … 显示 对 应 图 书信 息 
TmageButtonl ImageUrl; ~/image/ 图 标 /basket. bmp ”| 将 所 查 图 书 加 入 购书 篮 中 
TextBox2 Text:0 加 入 购书 篮 中 的 数量 
主要 代码 如 下 : 


(1) 公共 变量 


public static string sqlcon str - ConfigurationSettings .AppSettings ["sqlcon"]; 
public static SglConnection sqlcon - new SqlConnection (sqlcon str); 


public static string current bid- ""; // 当 前 书号 

public static string sqlstr; // 综合 查询 条 件 

(2) 图 书信 息 显示 函数 show_single( ) 

protected void Show Single () // 显 示 书号 为 Bid 的 图 书 明细 


{ 


SqlCormand sqlcom new SqlCommand () ; 
SqlDataReader dr; 
sqlcom.Connection -sqlcon; 
try 
{ // 从 主页 快速 查 书 ,热门 图 书 广告 或 新 特 书 传 来 的 图 书号 
current bid Request .QueryString["Bid"]; 
Session["Bid"] -current bid; 
) 
catch 
{ current bid-""; } 
if (current bid--"") && (GridViewl.Rows.Count »0)) // 显 示 列 表 中 的 第 一 本 书 
{ 
if (GridViewl.SelectedIndex ==-1) GridViewl .SelectedIndex -0; 
current bid-GridViewl.SelectedRow.Cells[0].ToString() ; 
) 
// 计算 可 用 书 数 量 


Sqlcom.CommandText -"select * ,num0 -numl as nm from Binfo where bid-'" +current bid +" 


if (sglcon.State —--ConnectionState.Closed) sqlcon.Open(); 
dr -sqicom.ExecuteReader () ; 
while (dr.Read()) 
{ 
Labell .Text = 书号 :" 4dr["bid"] .ToString() ; 
Label3.Text —"' 4 :" 4dr ["bname"] .ToString (); 
Label4.Text "Hi Gt. : " 4dr ["bpub"] .ToString() ; 
Label5.Text "作者 :" 4dr ["bauth"] .ToString() ; 
Label7.Text —"4]3É:" «dr ["bt1"]. ToString () +"," 4dr ["bt2"] . ToString () 4"," + 
dr["bt3"] .ToString() ; 
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Label8.Text 下 出 版 日 期 :" +dr ["bpdt"] .ToString 0 ; 
Label9.Text =" 书 价 :" +dr ["bpri"] .ToString() ; 
Label10.Text = 折扣 率 :" +dr["bf"] .ToString(); 
Iabel11 .Text 下 可 购 量 :" +dr ["nm"] .ToString(); 
TextBoxl .Text = 摘要 :" 4dr ["bad"] .ToString(); 
Tmage2 . ImageUr1 =" ~/image/book/" +dr ["bid"].ToString () . Trim () .Replace ("/", "") 
jpg; 
) 
dr.Close(); 


} 
(3) 自 定义 函数 : List_rst( sring skey) 


protected void List rst (string skey) // 列 出 书 名 或 作者 名 中 含有 skey 的 书籍 
i 

SqlCormand sqlcoml =new SqlConmand () ; 

SqlDataReader drl; 

sqlcoml .Connection =sqlcon; 

sqlcoml .CommandText ="select Bid, Bname, Bauth from Binfo where lower (Bname) like '%" + 

Skey ?"$' or Bauth like '%" +skey ?"$'"; 

if (sqlcon.State --ConnectionState.Closed) sqlcon.Open(); 

drl =sqlconml .ExecuteReader () ; 

GridViewl.DataSource -drl; 

GridViewl.DataBind(); 

drl.Close(); 
) 


(4) Page. Load( ) 事 件 


protected void Page Load (object sender, EventArgs e) 
{ 
SqlCormand sqlcoml new SqlConmand () ; 
SqlDataReader drl; 
if (! Page.IsPostBack) 
{ 
Show Single(); 
sqlcoml .Connection =sqlcon; 
sqlstr ="; 
try 
{í 
Llabel2.Text = 当前 登录 账号 : " 4Session["Uid"].ToString() +" (" + 
Session ["Uname"] .ToString () +")"; 
catch 
{ Label2.Text "KER"; ) 
try 
t 
sqlstr Request .QueryString["skey"] ; 
if (sqlstr.Length >0) TextBox4.Text -sqlstr; 
} 
catch 
{ sqlstr "9999"; } 


} 
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if (sqlstr--"") sqlstr ="9999"; 
List rst (sqlstr); 
update typedrd(); 


(5) 1848 Button1_ Click( ) 事 件 


protected void Buttonl Click (object sender, EventArgs e) 


{ 


) 


if (TextBox4 . Text .Length > 0) 
{ 
List rst (TextBox4.Text); 
sqlstr -TextBox4 . Text ; 


(6) 详细 查询 Button2, Click( ) 事 件 


protected void Button2 Click (object sender, EventArgs e) 


{ 


string sqlbinfo; 

DataSet ds new DataSet () ; 

string dtl,dt2,ddt; 

dt1 ="2000 -01 -01"; 

dt2 ="2010 32 31"; 

ddt -TextBoxll.Text.Trim(); 

// 条 件 判断 

Sqlbinfo -"bid»'0'"; 

if (TextBox7.Text.Trim().Length 0) sqlbinfo +=" and Bid like '%" 4TextBox7.Text.Trim 
() erm; 

if (TextBox8.Text.Trim().Length 50) sqlbinfo +=" and Bname like '$" 4TextBox8.Text. 
Trim() "$'"; 

if (TextBox9.Text.Trim().Length 50) sqlbinfo +=" and Bauth like '%" 4TextBox9.Text. 
Trim() "$'"; 

if (TextBox10.Text.Trim().Length 50) sqlbinfo +=" and Bpub like '$" +TextBox10 . Text. 
Trim() ?"$'"; 

if (TextBox1l.Text.Trim().Length 0) 

{ 
dtl -ddt.Substring (0,4) +" -01 -01"; 
dt2 -ddt .Substring (5,4) +" -12 31"; 
sqlbinfo +=" and bpdt >=' 4dt1 4"' and bpdt < ="" 1dt2 +"'"; 

) 

if (DropDownlist6.Text! = 不 限 ") sqlbinfo +=" and bt1 -'" 4DropDownList6.Text +"'"; 

if (DropDownList7.Text! 一 不 限 ") sqlbinfo +=" and bt2 -'" 4DropDownList7 .Text 4"'"; 

if (DropDownList8 Text! —J"R[R") sqlbinfo +=" and bt3 -'" 4DropDownList8 .Text +"'"; 


SqlDataAdapter da -new SqlDataAdapter ("select * from Binfo where " 4sqlbinfo, sqlcon); 
if (sglcon.State --ConnectionState.Closed) sqlcon.Open(); 

da.Fill (ds, "Binfo"); 

GridViewl .DataSource =qs .Tables [0] .DefaultView; 

GridViewl .DataBind(); 
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(7) 图 书 列表 GridView2_SelectedIndexChanged( ) 事 件 


protected void GridViewl SelectedIndexChanged (object sender, EventArgs e) 


-GridViewl.SelectedDataKey.Value.ToString(); 
item select(); //item select ()5j Show Single () 类 似 


(8) 加 入 购书 篮 ImageButton1_Click( ) 事 件 


protected void ImageButtonl Click (object sender, ImageClickEventArgs e) 


string Bid -Session["Bid"].ToString(); // 当 前 书号 

SqlCommand sqlcoml -new SqlConmand () ; 

SqlDataReader drl; 

string Uid; // 当 前 用 户 ID, 由 Bia 和 Uid 构 成 书 篮 的 联合 主键 
string bname -"", bpri -"", bf ="" ,bcout 7""; // 书 名 ,单价 ,折扣 率 ,数量 
Boolean yn -false, yn bas -false; // 是 否 存在 该 书 


if (Session["Utype"]! -"MyUser") {showmessage ("请 先 登 录 ,才能 购书 ") ; return; ) 
try 
{ 
Uid =Session["Uid"] .ToString (); 
} 
catch 
{ 
Uid-"999"; 
) 
Label2.Text = 当前 书号 :" 4Bid +" 当前 用 户 :" + " 40id; 
sqlcoml .Connection -sqlcon; 
sqlcoml .CommandText -"select bname,bpri,bf from Binfo where BID ='" 4Bid ?"'"; 
if (sqlcon.State —-ConnectionState.Closed) sqlcon.Open(); 
drl =sqlcoml .ExecuteReader () ; 
while (drl.Read()) 
{ 
bname =dr1 [0] .ToString(); 
bpri -drl [1] .ToString() ; 
bf -dr1 [2] .ToString () ; 
yn-true; 
) 
drl.Close(); 
bcout -TextBox2.Text; 


// 加 入 购书 篮 
if (yn) // 书 存在 
{ // 先 判断 购书 篮 中 是 否 已 有 该 书 ,如 有 则 加 减 数量 


sqlcoml .ConmandText -"select + from bas d where BID-'" Bid +"' and id='" id +"'"; 
if (sqlcon.State --ConnectionState.Closed) sqlcon.Open(); 
drl =sqlcoml .ExecuteReader () ; 

while (drl.Read ()) 

{ 

yn bas -true; 

} 

dr1.Close(); 

if(yn bas) 
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sqlcoml .CommandText -"update bas d set bcout -bcout +" tbcout +" where BID 
=" Bid +"' and id-'" Wid +"'"; 


else 
sqlcoml .ConmandText ="insert into bas d values ('" Wid +"','" Bid +"', 
'" dbname +"'," 4bcout +", " Hopri +", " Hof +") "7 


try 
{ 
sqlcoml .ExecuteNonQuery () ; 
shownessage ("加 入 购书 篮 成 功 ") ; 


) 
catch ( shownessage ("操作 失败 ,请 查看 数据 是 否 合法 "); } 
) 
9.4.4. 我 的 订单 
“我 的 订单 "模块 为 本 项 目的 主要 业务 ,图 9-7 是 用 户 订 书 的 一 般 流程 ,图 9-8 所 示 为 
“我 的 订单 "模块 的 两 个 页 面 。 


查 书 IH JAM H 加 减 删 订 书 数 - 加 入 订单 H ÀT ie S 确认 订单 lH 执行 订单 


图 9-7 订 书 流程 


(a) “购书 得 "页面 
Ie [ADISI] xeeizogmt PXE 20L03.16 
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(b) “我 的 订单 "页 面 
9-8 “我 的 订单 "模块 


表 9-16、 表 9-17 为 图 9-8 所 示 页 面 的 主要 控件 的 属性 和 作用 。 
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表 9-16 “购书 篮 "页 面 控件 的 属性 和 作用 


控 fF mD 主要 属性 作 用 
Menul Items; 购书 篮 和 订单 切换 上 部 菜单 
显示 当前 用 户 账 号 、 篮 中 书 数 应付 
TextBox2 ~ TextBox5 Enabled ; False 金额 可 用 积分 
Buttonl Text: 刷新 重新 汇总 TextBox3 ~ TextBox5 信息 
Button2 Text; 清空 购书 篮 快速 搜 书 
"T 字段 :书号 BA 数量 单价 ,折扣 率 ; | 当前 购书 篮 明 细 , 可 修改 数量 或 删 
超 链接 :选择 编辑、 删除 除 单条 记录 
表 9-17 “我 的 订单 ”页 面 控件 的 属性 和 作用 
控 (Pom 主要 属性 作 用 
TextBoxl 订单 号 
TextBox6 Tooltip; 格式 yyyy-mm-dd,vk 2010-01-01 | 下 单 起 始 日 期 
TextBox7 下 单 终止 日 期 
RadioButtonList7 Items: 新 单 .确认 完成 .不 限 订单 状态 
DropDownList5 ~ Ttems 在 页 面 装载 时 从 表 Btypel ~ Btype3 | 一 
DropDownList7 读 人 ii 
Button6 Text: 查询 执行 综合 查询 
GridViewl 查询 结果 简明 图 书 列表 图 书 列表 ,选择 时 显示 具体 图 书信 息 
TextBox8 等 具体 订单 信息 
RadioButtonListl Items; 新 单 .确认 完成 当前 订单 状态 
Button3 Text: 新 建 单 新 建 订单 ,订单 号 由 系统 自动 计算 
Button4 Text: 保存 修改 保存 新 订单 和 修改 旧 订 单 
从 购书 篮 导 入 明细 ,存在 相同 的 书 
Button5 Text: 导入 明细 号 时 不 导入 ,数量 可 编辑 
" 用 户 确认 订单 ,确认 后 进入 执行 流 
mon piii 程 ,订单 信息 不 可 修改 
Button8 Text: 删除 删除 当前 用 户 的 新 单 
GridView2 Items; 书号 , 书 名 数量 ,折扣 率 、 选 \ 编 . 删 | 订单 明细 ,新 订单 可 删改 
“购物 车 "页 面 的 主要 代码 如 下 : 


(1) 公共 变量 


public static string sqlcon str -ConfigurationSettings .AppSettings ["sqlcon"]; 
public static SqlConnection sqlcon -new SglConnection (sqlcon str); 
public static string sqlbinfo -""; // 订 单 查询 条 件 
public static string usertp -""; 

// 当 前 选中 用 户 类 型 ,用 于 用 户 类 型 的 设置 ,判断 是 新 增 还 是 修改 
int curpage user -Ü,curpage book -0,curpage order -0; 

// 记 录 查 询 的 当前 页 ,以 便 在 重新 绑 定 时 页 面 保持 不 变 

public static int ins edt -0; // 订 单 查询 处 于 修改 状态 为 0, 插 入 状态 为 1 
public static string Uid -""; // 用 户 1D 


第 9 章 网 上 书店 开发 实例 


(2) Page. Load( ) 事 件 


protected void Page Load (object sender, EventArgs e) 
{ 
// 防 止 非 会 员 用 户 直接 进入 订单 管理 页 面 ,一 旦 非法 进入 即 转向 首页 
if (Session["Utype"] ! -"MyUser") 
{ 
shownessage (" 请 先 登 录 再 进入 订单 管理 页 面 "); 
Response.Redirect ("default .aspx"); 
) 
try 
i 
Uid ession ["Uid"] .ToString () ; 
} 
catch { Uid=""; } 


sqlbinfo =" wb='" tid +"' and state 0"; 


catch 
{ 
sqlbinfo =" state -0"; 
} 
if (! Page.IsPostBack) 
{ 
Label9.Text -Session["login ms"].ToString(); 
Button] .Attributes.Add ("onclick", "return confim(' 订 单一 旦 确认 将 无 法 修改 ,要 确 
认 吗 ? ') ;true"); 
menu ev (" 购 书 篮 ") ; 


(3) 菜单 切换 事件 


protected void Menul MenultemClick (object sender,MenuEventArgs e) 


menu ev (Menul .SelectedValue); 


protected void menu ev (string menuval) 


SglDataAdapter da bas -new SqlDataAdapter ("select * from bas d where id -'" HUid ?"'", 
Sqlcon); 
SglDataAdapter da ord -new SqlDataAdapter ("select * from order info where "+ 


sqlbinfo, sqlcon) ; 
DataSet ds bas -new DataSet () ; // 账 号 为 mida 的 用 户 的 购书 篮 明细 
DataSet ds ord-new DataSet () ; // 账 号 为 id 的 用 户 的 新 订单 头 信息 


user m.Visible -false; 

book m.Visible false; 

// 单 击 购书 篮 图 标 时 ,显示 当前 用 户 购书 篮 中 图 书 明细 和 总 数 
if (menuval = 二 购书 篮 ") 
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} 


user m.Visible true; 

book m.Visible =false; 

if (sqlcon.State --ConnectionState.Closed) sqlcon.Open(); 
da bas.Fill(ds bas, "bas d"); 

GridViewl.DataSource «ds bas.Tables[0].DefaultView; 
GridViewl.DataBind(); 

TextBox2 .Te 


TextBox5.Text ="; 
TextBox2 .Text -Uid; 
// 计 算 图 书 总 数 
string comtxt ="select sum(a.bcout),sum(a.bcout * bpri * bf),sum(b.pcount) from 
bas da, Puser b where a.id-'" 3Uid ?"' and b.id-'" Wid ?"' group by a. id"; 
SqlConmand sqlcom =new SqlConmand (comtxt, sqlcon) ; 
SqlDataReader dr -sqlcom.ExecuteReader () ; 
while (dr.Read()) 
4 
TextBox3.Text -dr [0] .ToString(); 
TextBox4.Text =dr [1] .ToString(); 
TextBox5 .Text =dr [2] .ToString () ; 
j 
dr.Close(); 
) 
if (menuval ==" 我 的 订单 ") 
{ 
user m.Visible =false; 
book m.Visible -true; 
if (sqlcon.State —--ConnectionState.Closed) sqlcon.Open(); 
da ord.Fill(ds ord,"order info"); 
GridView3.DataSource -ds ord.Tables [0] .DefaultView; 
GridView3.DataBind(); 


(4) Buttonl. Click ( ) 事 件 


protected void Buttonl Click (object sender, EventArgs e) 


上 


SqlDataAdapter da bas -new SqlDataAdapter ("select * from bas d where id-'" 4Uid 4" '", 
sqlcon); 

SglDataAdapter da ord-new SqlDataAdapter("select + from order info where wb -'" Uid 
+"' and state -0",sqlcon); 

SglDataAdapter da ord d-new SqlDataAdapter ("select * from order d where id='@ id'", 


Sqlcon); 
DataSet ds bas -new DataSet () ; // 账 号 为 id 的 用 户 的 购书 篮 中 图 书 明 细 
DataSet ds ord-new DataSet () ; // 账 号 为 Uid 的 用 户 的 新 订单 头 信息 
DataSet ds ord d-new DataSet () ; // 单 号 为 id 的 订单 明细 


if (sqlcon.State ==ConnectionState.Closed) sqlcon.Open(); 
da bas.Fill(ds bas,"bas d"); 


} 


第 9 章 网 上 书店 开发 实例 


GridViewl.DataSource -ds bas.Tables[0].DefaultView; 
GridViewl.DataBind(); 
TextBox2.Text ="; 
TextBox3.Text ="; 
TextBox4 .Text —'"; 
TextBox5.Text =""; 
TextBox2 .Text Uid; 
// 计 算 图 书 总 数 
String comtxt -"select sum(a.bcout), sum (a.bcout * bpri * bf),sum(b.pcount) from bas d 
a, Puser b where a.id-'" tid +"' and b.id-'" id +"' group by a.id"; 
SqlComrmand sqlcom -new SqlCommand (comtxt, sqlcon) ; 
SglDataReader dr -5qlcom.ExecuteReader () ; 
while (dr.Read()) 
{ 
TextBox3.Text =dr [0] .ToString () ; 
TextBox4 .Text =dr [1] .ToString () ; 
TextBox5 .Text =dr [2] .ToString() ; 
} 
dr.Close(); 


(5) Button2, Click( ) 事 件 


protected void Button2 Click (object sender, EventArgs e) // 清 空 购书 篮 


{ 


SqlCormand sqlcom new SqlCommand ("delete from bas d where id -'" * Uid + "'",sglcon); 
if (sqlcon.State —-ConnectionState.Closed) sqlcon.Open(); 
try 
{ 
sqlcom.ExecuteNonQuery () ; 
Buttonl Click (sender,e) ; 
shownessage ("该 用 户 的 购书 篮 已 清空 "); 
} 
catch {showmessage ("操作 失败 ") ; 


(6) GridViewl 编辑 ,删除 事件 


protected void GridViewl RowEditing (object sender, GridViewEditEventArgs e) 


if (GridViewl.SelectedIndex---1) ( showmessage (" 先 选择 后 编辑 !") ; return; } 
GridViewl .EditIndex -e.NewEditIndex; 
menu ev (" 购 书 篮 ") ; 


protected void GridViewl RowCancelingEdit (object sender, GridViewCancelEditEventArgs e) 


GridViewl.SelectedIndex --1; 
GridViewl.EditIndex =-1; 
menu ev (" 购 书 篮 ") ; 


protected void GridViewl RowUpdating (object sender, GridViewUpdateEventArgs e) 
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SqlCommand updt new SqlConmand ("", sqlcon); 
string Nm=( (TextBox) (GridViewl Rows [e.RowIndex] .Cells [4] .Controls[0])) .Text; 
string bid-GridViewl .SelectedRow.Cells [0] .Text; 
updt .ConmandText ="update bas d set bcout =" +m +" where id-'" 4Uid +"' and bid -'" ibid 
nies 
if (sqlcon.State --ConnectionState.Closed) sqlcon.Open(); 
try 
{ updt .ExecuteNonguery () ; } 
catch { }; 
GridViewl.EditIndex --1; 
menu ev ("WBE") ; 
) 
protected void GridViewl RowUpdated (object sender, GridViewUpdatedEventArgs e) 
i 
GridViewl.SelectedIndex =-1; 
menu ev ("WRM"); 
) 


“我 的 订单 "页 面 的 主要 代码 如 下 : 
(1) 综合 查询 Button6_Click( ) 事 件 


protected void Button6 Click (object sender, EventArgs e) 
{ 
sqlbinfo -"wb ='" 4Session["Uid"] +"'"; 
// 订 单 号 支持 模糊 查询 ,如 要 查看 某 一 日 订单 , 则 输入 yyrmod 
if (TextBoxl.Text.Length >0) sqlbinfo +=" and Bid like '$" +TextBox1 .Text +"%'"; 
if (TextBox6.Text.length 20) sqlbinfo +=" and Bdt »-'" 4TextBox6.Text +"'"; 
if (TextBox7.Text.length >0) sqlbinfo +=" and Bdt «-'" +TextBox7 .Text +"'"; 
if (RadioButtonList7.SelectedIndex 3) sqlbinfo +=" and state =" + 
RadioButtonList7.SelectedIndex.ToString|(); 
menu ev (Menul .SelectedValue); 
) 


(2) GridView3 记录 选择 事件 


protected void GridView3 SelectedIndexChanged (object sender, EventArgs e) 
// 订 单列 表 更 新 时 
{ 
updt order(); 
} 


// 函 数 updt_order () 在 用 户 每 次 单 击 订单 记录 时 用 于 更 新 订单 信息 
protected void updt order () 
jl 
string Bid -GridView3.SelectedRow.Cells[1].Text; 
// 刷 新 订单 
string uptcomtxt -"update order info set tb =(select sum(bcout) from order d where id= 
'" Bid ?"' group by id)"; 
uptcomtxt +=", tp1 =(select sum(bcout* bpri) from order d where id-'" +Bid +"' group by 
id)"; 
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uptcomtxt +=", tp2 =(select sum (bcout* bpri* bf) from order d where id-'" +Bid +"' 
group by id) where bid-'" Bid #"'"; 

SqlConmand upt com -new SqlCommand (uptcomtxt, sqlcon); 

if (sqlcon.State --ConnectionState.Closed) sqlcon.Open(); 

try 

{ 


upt com.ExecuteNonQuery () ; 
} 
catch { } 
SqlDataAdapter da =new SqlDataAdapter ("select + from order info where Bid ='" + 
Bid-"'", sglcon); 
DataSet ds -new DataSet () ; 
SglDataAdapter da d -new SqlDataAdapter ("select + from order d where id-'" + 
Bid-"'", sqlcon); 
DataSet ds d-new DataSet () ; 
if (sqlcon.State --ConnectionState.Closed) sqlcon.Open(); 
da.Fill(ds, "order info"); 
da d.Fill(ds d, "order d"); 
DataTable tb -ds.Tables [0]; 
DataRow tb row -tb.Rows [0]; 
GridView2 .DataSource -ds d.Tables [0] .DefaultView; 
GridView2 .DataBind(); 
TextBox8.Text -tb row["bid"].ToString(); 
TextBox9.Text tb row["wb"].ToString(); 
TextBox10 .Text -(DateTime.Parse (tb row["bdt"] .ToString ())) .ToString ("d") ; 
TextBoxll.Text tb row["tb"].ToString(); 
TextBox12.Text tb row["tpl"].ToString(); 
TextBox13.Text -tb row["tp2"].ToString(); 
TextBox15.Text -tb row["prepay"] .ToString(); 
TextBox17 .Text tb row["contact"].ToString(); 
TextBox16.Text tb row["addr"].ToString(); 
TextBox18.Text tb row["tel"].ToString(); 
RadioButtonListl.SelectedIndex -Int32.Parse (tb row|["state"] .ToString()); 
ins edt-0; // 当 前 为 修改 记录 状态 
if (RadioButtonListl.SelectedIndex! -0) 
{ 
GridView2 .Columns [6] .Visible =false; 
GridView2 .Columns [7] .Visible =false; 
} 
else 
{ 
GridView2 .Columns [6] .Visible true; 
GridView2 .Columns [7] .Visible «rue; 
} 
SqlConrmand op_coml new SqlConmand ("select sum(a.Pcount) from Puser a where a.id="'"+ 
Uid-"' group by a.id", sqlcon); 
SqlDataReader da 1; 
SglCommand op com? -new SqlCommand ("select sum (prepay) from order info where wb-'" + 
Uid +"' and state 4 group by wb", sqlcon); 
SqlDataReader da 2; 
int sm -0, sun -0; 
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} 


da 1-op comi .ExecuteReader () ; 
while (da 1.Read()) 
{ 
sumi =int .Parse (da 1[0].ToString()); 
) 
da 1.Close(); 
da 2 =p con? .ExecuteReader () ; 
while (da 2.Read()) 
{ 
sun? -int Parse (da 2[0] .ToString ()) ; 
} 
da 2.Close(); 
sm --sum2; 
kyjs.Text =suml .ToString() ; // 显 示 用 户 可 用 积分 


(3) 新 建 订单 Button3_Click( ) 事 件 


protected void Button3 Click (object sender, EventArgs e) 


{ 


string curdat -DateTime.Now.ToString ("yyMMdd") ; 
// 注 意 :大 写 MM 代 表 占 两 位 的 月 份 ,小 写 代表 占 两 位 的 分 钟 


curdat —curdat . Replace (" -", "") ; // 当 前 日 期 的 YwMMaa 格式 ,如 100903 
// 订 单 中 当前 日 期 的 最 大 值 
string cur id =curdat +"001"; // 当 前 日 期 的 第 一 个 订单 号 


SqlCommand maxid com -new SqlCommand ("select max (Bid) from order info where Bid like 
'" 4curdat +"%'", sqlcon) ; 


SqlDataReader dr; 

if (sqlcon.State —-ConnectionState.Closed) sqlcon.Open(); 
RadicButtonlistl.SelectedIndex -0; // 新 订单 状态 
dr -maxid com.ExecuteReader () ; 

// 获 取 当 日 最 大 单 号 


if (dr.RecordsAffected 50) 
{ 
while (dr.Read()) 
{ 
string maxn -dr [0] . ToString() -Substring (6, 3); 
int nm-Int32.Parse (maxn) d; 
string nmaxn -string.Format ("(0:000)", nm); 
cur id-cur id.Replace("001", nmaxn); 


} 

dr.Close(); 

TextBox8.Text-cur id; 

TextBox10 .Text -DateTime.Now.ToString ("d"); 

TextBox11.Text —"0"; 

TextBox12.Text —"0"; 

TextBox13.Text ="0"; 

TextBox15.Text —"0"; 

ins edt; // 当 前 为 插入 记录 状态 
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(4) 保存 修改 Button4_Click( ) 事 件 


protected void Button4 Click (object sender, EventArgs e) 


{ 


} 


//ins ed: 保存 新 记录 ;ins ed-0 :保存 修 改 记录 
SqlCommand ins edcom new SqlConmand ("", sqlcon); 
if (Int32.Parse (TextBox15 .Text) »Int32.Parse (kyjs.Text)) 
{ 
showmessage ("预付 积分 不 能 大 于 可 用 积分 ") ; 
return; 
} 
switch (ins edt) 
{ 
case 0: // 修 改 记录 , 当 订单 未 确认 时 有 效 
ins edcom.CommandText ="update order info set prepay =" +TextBox15.Text +", addr = 


wm, 
; 


ins edcom.CammandText 4 -TextBoxl6.Text +"", contact ="" ATextBox17 .Text 4"',tel-'" ; 
ins edcom.CommandText + -TextBox18.Text +"' where Bid -'" *TextBox8.Text +"' and 
state -0"; 
break; 
case 1: // 增 加 记录 
ins edcom.CommandText ="insert into order info values ('" +TextBox8 .Text +"', 
'" 4Session["Uid"].ToString() "', '"; 
ins edcom.CommandText + -TextBox10.Text +"', 0,0,0,0, '" 4TextBox16. Text +" ', 
'" ATextBox18. Text +"','"; 
ins edcom.CommandText *-TextBoxl7.Text $"',0)"; 
break; 
) 
if (sqlcon.State —-ConnectionState.Closed) sqlcon.Open(); 
try 
{ 
ins_edcom.ExecuteNonQuery () ; 
ins edt-0; 
shownessage ("操作 成 功 ") ; 
) 
catch ( shownessage ("操作 失败 "); } 
//Label14.Text -ins edcom.CommandText; // 此 处 测试 插入 /修改 命令 
RadioButtonList7.SelectedIndex -0; 
Button6 Click (sender,e); 


(5) 删除 订单 Button8_Click( ) 事 件 


protected void Button8 Click (object sender, EventArgs e) 


{ 


SqlCommand del ord d new SqlCormand ("", sqlcon); 

SqlCormand del ord new SqlCommand ("", sqlcon); 

string bid -TextBox8 .Text; 

if (bid.Trim().Length --0) return; 

if (RadioButtonListl. SelectedIndex »0) { showmessage ("不 是 新 订单 ,不 能 删除 "); 
return; } 
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} 


del ord d.CommandText -"delete from order d where id='" tpid +"'" 
del ord.CommandText -"delete from order info where bid-'" tbid +"'"; 
if (sqlcon.State —-ConnectionState.Closed) sqlcon.Open(); 
SqlTransaction trl -sqlcon.BeginTransaction(); 
del ord d.Transaction «rl; 
try 
{ 
del ord d.ExecuteNonQuery (); 
tr1.Comit (); 
) 
catch ( trl.Rollback(); showmessage ("操作 失败 (step1)"); return; } 
trl.Dispose(); 
SqlTransaction tr2 -sqlcon.BeginTransaction() ; 
del ord.Transaction tr2; 
try 
{ 
del ord.ExecuteNonQuery () ; 
tr2 .Conmit () ; 
shownessage ("操作 成 功 ") ; 
} 
catch ( tr2 .Rollback() ; showmessage ("操作 失败 (step2)"); } 
Button6 Click (sender,e); 
if (GridView3.Rows.Count --0) ( GridView2 .DataSource -null; GridView2.DataBind(); } 


(6) 导入 明细 Button5. Click ( ) 事 件 


protected void Button5 Click (object sender, EventArgs e) 


{ 


/* 从 购书 篮 导入 明细 ,只 添加 订单 中 不 存在 的 条 目 * / 


SqlCormand ins_com new SqlConmand ("", sqlcon) ; 


if (TextBox8.Text.Length =-0) ( showmessage (" 订 单 号 不 存在 ") ; return; } 
ins com.CommandText -"insert into order d select * from bas d where id='" 4Session[" 
Uid"] +""' and bid not in "; 
ins com.CommandText +=" (select bid from order d where id -'" +TextBox8 .Text +"')"; 
if (sqlcon.State —-ConnectionState.Closed) sqlcon.Open(); 
try 
{ 
ins com.ExecuteNonQuery () 7 


) 
catch ( shownessage ("操作 失败 "); return; } 
ins com.CommandText -"update order d set id-'" +TextBox8 .Text +"' where id-'" +Session 
["Uid"] en; 
try 
{ 
ins com.ExecuteNonQuery () ; 
) 
catch ( shownessage ("操作 失败 ") ; return; } 
// 导 和 人 成功 即 删除 该 用 户 的 购书 篮 信息 


) 


第 9 章 网 上 书店 开发 实例 


ins com.CommandText -"delete from bas d where id-'" 1Session["Uid"] +""'"; 
try 
{ 
ins com.ExecuteNonQuery () ; 
shownessage ("操作 成 功 ") ; 
) 
catch ( shownessage ("操作 失败 "); } 
updt order(); 


(7) 订单 确认 Button7, Click ( ) 事 件 


protected void Button7 Click (object sender, EventArgs e) // 订 单 确认 


{ 


if (RadioButtonListl.SelectedIndex >0) ( showmessage ("已 确认 或 已 完成 "); return; } 
SqlCormand confirm ord new SglCommand ("update order info set state =1 where Bid-'" + 
TextBox8 .Text +"'", sqlcon); 


if (sqlcon.State --ConnectionState.Closed) sqlcon.Open(); 

confirm ord.ExecuteNonQuery () ; 

// 确认 时 ,订单 明细 所 涉及 的 书籍 预订 数量 累加 

SqlComrmand upt -new SqlConmand ("", sqlcon) ; 

upt .ConmandText -"update binfo set numl numl +(select bcout from order d b where b.id 
z'" JTextBox8 . Text +"' and b.bid -binfo.bid)"; 

upt.CommandText +=" where binfo.bid in (select bid from order d c where c.id-'" + 

TextBox8 .Text +"')"; 

upt .ExecuteNonQuery () ; 


(8) GridView3 编辑 .删除 事件 


protected void GridView2 PageIndexChanging (object sender, GridViewPageEventArgs e) 


GridView2.PageIndex -e.NewPageIndex; 


protected void GridView2 RowEditing (object sender,GridViewEditEventArgs e) 


if (GridView2.SelectedIndex ---1) { showmessage (" 请 先 选择 再 编辑 ") ; return; } 
GridView2 .EditIndex -e.NewEditIndex; 
updt order (); 


protected void GridView2 RowUpdating (object sender,GridViewUpdateEventArgs e) 


SqlCormmand updt -new SqlConmand ("", sqlcon) ; 

string Nn-((TextBox) (GridView2 .Rows [e .RowIndex] .Cells [2] .Controls[0])) .Text ; 

string bid -GridView2 .SelectedRow.Cells [0] Text; 

updt .ConmandText ="update order d set bcout =" 4Nm +" where id-'" +TextBox8 .Text +"' and 
bid-'"4pid-"'"; 

if (sglcon.State --ConnectionState.Closed) sqlcon.Open(); 

try 

{ updt.ExecuteNonQuery () ; } 
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} 


catch { }; 
GridView2 .EditIndex--1; 
updt order(); 


protected void GridView2 RowCancelingEdit (object sender, GridViewCancelEditEventArgs e) 


{ 


} 


GridView2 .EditIndex --1; 
updt order(); 


protected void GridView2 RowDeleting (object sender,GridViewDeleteEventArgs e) 


| 


) 


int ordsel -GridView3.SelectedIndex; 
string Bid -""; 
if (GridView2.SelectedIndex ---1) ( shownessage (" 先 选择 后 删除 !") ; return; } 
try 
{ 
Bid-GridView2.SelectedRow.Cells[0].Text; 
) 
catch ( Bid-""; } 
SqlCommand del -new SqlConmand ("delete from order d where id -'" +TextBox8 .Text +"' and 
bid-'" 4Bid 4?" '",sqlcon); 
if (sqlcon.State —-ConnectionState.Closed) sqlcon.Open(); 
try 
{ 
del .ExecuteNonQuery (); 
showmessage ("操作 成 功 !") ; 
} 
catch ( showmessage ("操作 失败 1") ; } 
updt order(); 


9.4.5 客服 中 心 


客服 中 心 模块 包括 “常见 问答 " “投诉 建议 “用 户 资料 修改 " “修改 用 户 密码 "功能 ， 
对 于 一 般 游 客 只 显示 常见 问答 ,注册 用 户 则 可 执行 投诉 建议 .修改 资料 和 密码 操作 。 
(1) 常见 问答 : 显示 与 本 系统 有 关 业 务 的 常见 客户 问题 和 回复 ,如 图 9-9 所 示 。 


E 你 的 搜 书 网 pss 日 BRE 2 iaa 1 BSEC C] ERI 

TEAS: | 

FS 解答 

Fou REST 

$85 aue REST 

and due Suede 

QUU pans aest 

BBS tame ases? 


9-9 常见 问答 设计 


(2) 投诉 建议 : 注册 用 户 通过 此 页 面 提出 投诉 或 建议 ,以 邮件 形式 发 送 到 系统 指定 邮 
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箱 , 如 图 9-10 所 示 。 


到 


Bes wes] 


图 9-10 投诉 建议 设计 


(3) 用 户 资料 修改 : 转 入 用 户 注册 页 面 “regist. aspx?addored =1”。 

(4) 修改 用 户 密码 : 注册 用 户 修改 密码 。 

首次 登录 此 页 面 时 ,显示 常见 问答 ,此 时 “用 户 修改 密码 "面板 不 可 见 , 当 注册 用 户 单 击 
导航 菜单 “修改 用 户 密码 "时 ,用 户 修改 密码 "面板 可 见 。 

本 页 面 控件 较为 简单 清晰 ,这 里 不 一 一 列 出 。 

“客服 中 心 "模块 的 主要 代码 如 下 : 

(1) 菜单 Menul 单 击 事件 


protected void Menul MenultemClick (object sender,MenuEventArgs e) 
{ 
if (Session["Utype"]! -"MyUser" && Menul.SelectedValue! "常见 问题 ") 
{ 
showmessage ("您 尚未 登录 ,不 能 执行 此 项 菜单 ") ; 
return; 
} 
if (Menul.SelectedValue = 二 "常见 问题 ") ( Pqs.Visible =true; Panel user.Visible =false; 
Panell .Visible -false ; ) 
if (Menul.SelectedValue ==" 投 诉 建议 四 ( Pqs.Visible =false; Panel user.Visible true; 
Panell.Visible -false;]) 
if (Menul.SelectedValue = 下 用 户 资料 修改 ") 
{ Response.Redirect ("regist .aspx?addored3"); } 
if (Menul.SelectedValue = 二 修改 用 户 密码 ") { Panel user.Visible =false;Panell .Visible 
true; } 


) 
(2) Page. Load( ) 事 件 


protected void Page Load (object sender, EventArgs e) 
{ 
if (! Page.IsPostBack) 
{ 
if ((Session["Utype"] --"Administrator uso") || (Session["Utype"] —-"MyUser")) 
{ 
Menul . Items [2] .Enabled true; 
Menul . Items [3] .Enabled true; 
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} 


show qa; 
Panel user.Visible -false; 


函数 show. qa( ) 用 于 从 QA. xml 读 人 记录 并 显示 在 GridViewl 中 。 


protected void show qa () 


í 


DataSet qa ds -new DataSet () ; 

qa ds.ReadXml (Server .MapPath (" ~/xml /QA. xml") ) ; 
GridViewl.DataSource -qa ds.Tables[0] .DefaultView; 
GridViewl.DataBind(); 


(3) 投诉 建议 发 送 Button]. Click( ) 事 件 


protected void Buttonl Click (object sender, EventArgs e) 


SendMailUseZj(); 


函数 SendMailUseZj( ) 用 于 进行 邮件 发 送 处 理 。 


public void SendMailUseZj() 


if (Session["Utype"]! -"MyUser") 
{ showmessage ("请 先 登 录 ! ") ; 


return; } 


// 创 建 一 个 邮件 对 象 
System.Net.Mail.MailMessage msg new System.Net .Mail.MailMessage (); 
// 读 取 Webconfig 中 的 配置 


string mailTo -ConfigurationSettings.AppSettings ["mailTo"]; // 主 发 送 邮箱 
string mailTob -ConfigurationSettings.AppSettings ["mailTob"]; // 次 发 送 邮箱 
string mailFrom=ConfigurationSettings .AppSettings ["mailFrom"]; // 源 发 送 邮箱 
string Psd =ConfigurationSettings .AppSettings ["mailPsd"]; // 源 发 送 邮箱 密码 


string mailHost =ConfigurationSettings .AppSettings ["mailHost"]; // 源 邮箱 服务 器 
// 指 定 收 件 人 ,可 以 发 送 给 多 人 
msg.To.Add (mailTo); 
msg. To. Add (mai lTob) ; 
// 指 定 发 件 邮箱 
msg.From-new MailAddress (mailFrom, "jyc", System. Text .Encoding.UTF8) ; 
/* 上 面 3 个 参数 分 别 是 发 件 人 地 址 (可 以 随便 写 ) 发 件 人 姓名 .编码 * / 


msg.Subject -TextBoxl .Text; // 邮 件 标题 
msg. SubjectEncoding -System. Text . Encoding .UTF8; // 邮 件 标题 编码 
msg.Body -TextBox2 .Text; // 邮 件 内 容 


msg.Body +=" \e" + 客户 账号 : " 4Session["Uid"] +" \r 客 户 名 称 : "+Session ["Uname"] + 
"\r 客户 电邮 : "+Session ["UEmail"]; 

msg .Body +=" \r" 4DateTime .Now. ToString() ; 

msg. BodyEncoding -System. Text . Encoding .UTF8 ; // 邮 件 内 容 编码 
msg. IsBodyHtml -false; // 是 否 是 HM 邮件 


} 
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msg.Priority -MailPriority.High; // 邮 件 优 先 级 
SmtpClient client -new SmtpClient () ; 
client.Credentials -new System.Net .NetworkCredential (mailFrom, Psd) ; 
// 发 送 邮箱 ( 非 客 户 邮箱 ) 和 密码 
client.Host -mailHost; 
object userState msg; 
try 
| 
client.Send (msg) ; 
Page. ClientScript.RegisterStartupScript (this.GetType () , ", "alert (' 发 送 成 功 ! 
');",true); 
) 
catch (System.Net.Mail.SmtpException ex) 
{ 
Page.ClientScript.RegisterStartupScript (this.GetType (),"", "alert (' 发 送 邮 件 出 
错 ! ') 7 ",true); 


(4) 确认 修改 密码 Button3_Click( ) 事 件 


protected void Button3 Click (object sender, EventArgs e) 


{ 


9.4.6 


后 台 管 理 是 本 系统 的 另 一 个 重要 功能 模块 ,用 户 以 管理 员 身份 登录 时 ,如 验证 正 


SqlCormand user psd new SqlCormand ("", sqlcon); 
if (Page.IsValid) 
( 
user psd.ConmmandText -"update Puser set Psecr -'" +msc.Makescr (TextBox4. Text, 
Secr) +"' where id-'" 4Session ["Uid"] .ToString() ?"'"; 
if (sqlcon.State --ConnectionState.Closed) sqlcon.Open(); 
try 
| 
user psd.ExecuteNonQuery () ; 
shownessage (" 密 码 修改 成 功 ! ") ; 
} 
catch ( showmessage ("密码 修改 失败 !"); } 


后 台 管 理 


确 , 直 接 进 入 后 台 管 理 界面 。 后 台 管 理 模块 包括 “用 户 管理 " “订单 管理 " “书籍 管 
H DÍE, 

1. 用 户 管理 

处 理 注册 用 户 综合 查询 修改 用 户 状态 和 用 户 积分 等 ,界面 如 图 9-11 所 示 。 

(1) 菜单 Menul_MenultemClick( ) 事 件 


protected void Menul MenuItemClick (object sender,MenuEventArgs e) 


{ 
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user m.Visible -false; 
order m.Visible -false; 
book m.Visible -false; 
if (Menul.SelectedValue ==" 用 户 管理 ") 
{ 
user m.Visible true; 
order m.Visible -false; 
book m.Visible -false; 
Buttonl Click (sender,e) ; 
} 
if (Menul .SelectedValue ==" 订 单 管理 ") 
{ 
user m.Visible =false; 
order m.Visible true; 
book m.Visible -false; 
Buttonl4 Click (sender,e); 
} 
if (Menul .SelectedValue ==" 书 籍 管理 ") 
{ 
user m.Visible =false; 
order m.Visible -false; 
book m.Visible rue; 


} 


(2) 公共 变量 


public static string sqlcon str -ConfigurationSettings .AppSettings ["sqlcon"]; 
public static SqlConnection sqlcon new SglConnection (sqlcon str); 


public static string sqlif -" id»'0' "; 
public static string sqlbinfo -"bid»'0'"; 
public static string usertp -""; 


// 用 户 查询 条 件 
// 书 籍 查询 条 件 


// 当 前 选中 用 户 类 型 ,用 于 用 户 类 型 的 设置 ,判断 是 新 增 还 是 修改 
public static int curpage user -0, curpage book -0,curpage order -0; 
// 记 录 查 询 的 当前 页 ,以 便 在 重新 绑 定 时 页 面 不 变 


public static int ins edt-0; // 书 籍 查询 处 于 


修改 状态 时 为 0, 处 于 插入 状态 时 为 1 
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public static string order sql -"state 40"; // 查 询 所 有 已 确认 订单 的 条 件 
(3) Page_Load ( ) 事 件 


protected void Page Load (object sender, EventArgs e) 


{ 


} 


// 防 止 非 管理 员 直接 进入 后 台 管理 页 面 ,一 旦 非法 进入 即 转向 首页 
if ((Session ["Uid"]! -"admin") || (Session ["Uname"]! 二 管理 员 ") ) Response. Redirect 
("default.aspx"); 
SqlCormmand sqlcom new SqlCommand ("select * from Pusertype", sqlcon) ; 
SqlCommand sqlcomBtl new SqlCommand ("select * from Btypel",sqlcon); 
SqlConrmand sqlcomBt2 -new SqlCommand ("select * from Btype2", sqlcon); 
SqlCommand sqlcomBt3 -new SqlCommand ("select * from Btype3", sqlcon); 
SqlDataReader dr; 
SqlDataAdapter da -new SqlDataAdapter (sqlcom.CommandText , sqlcon) ; 
SqlDataAdapter dal -new SqlDataAdapter (sqlcomBt1 . ConmandText , sqlcon) ; 
SqlDataAdapter da2 -new SqlDataAdapter (sqlcomBt2 . ConmandText , sqlcon) ; 
SqlDataAdapter da3 -new SqlDataAdapter (sqlcomBt3 . ConmandText , sqlcon) ; 
DataSet setting abc -new DataSet () ; 
if (! Page.IsPostBack) 
{ 
update typedrd(); 
Label9.Text -""; 
Llabelll.Text =""; 
Labell2.Text =""; 
cert.Attributes.Add ("onclick", "return confizm(" 订 单一 旦 确认 完成 将 无 法 修改 ,要 确 
UG? ') ;true") ; // 订 单 确认 完成 时 的 提示 信息 
Buttonl5.Attributes.Add ("onclick", "return confirm(" 确 认 要 删除 吗 ? ') ;true") ; 


(4) 综合 查询 Button1_Click( ) 事 件 


protected void Buttonl Click (object sender, EventArgs e) 


{ 


SqlCammand sqlcom new SqlConmand () ; 
DataSet ds -new DataSet () ; 
Sqlif-"select* from Puser where ID »'0' "; 
if (TextBoxl.Text.Length 20) sqlif *-"and ID like '$" iTextBoxl.Text +"%' "; 
if (TextBox2 .Text.Length 20) sqlif +="and Pname like '$" 4TextBox2.Text +"%' "; 
if ((DropDownListl.SelectedIndex >0) && (DropDownListl.Text.length >0)) sqlif += 
"and Ptype ="" 4DropDownListl.Text +"' "; 
switch (RadioButtonListl.SelectedIndex) 
{ 
Case 0: 
sqlif *-"and Pef -0"; 
break; 
casel: 
sqlif *-"and Pef d"; 
break; 
case 2: 
sqlif +="and Pef 9"; 


235 


236 ASP. NET 网 站 开发 案例 教程 
es 


break; 
) 
switch (RadioButtonList2 .SelectedIndex) 
{ 
case 0: 
sqlif +="and Psex giipve. 
break; 
case 1: 
sqlif t-"and Psex -'Sj '"; 
break; 


} 
if (DropDownList2.SelectedIndex »0 && DropDownList2 .Text.Length »0) 
{ 

string st, st1, st2; 

int lth -0,ps -0; 

st -DropDownList2.Text; 

lth-st.Length; 

ps »st.IndexOf (' -'); 

st1 -st.Substring (0,ps) ; 

st2 -st.Substring (ps 1,1th -ps 31); 

sqlif +=" and Pcount >=" 4st1 +" and Pcount <=" 4st2; 
) 
if (sqlcon.State —-ConnectionState.Closed) sqlcon.Open(); 
SqlDataAdapter da -new SglDataAdapter (sqlif,sqlcon); 
da.Fill (ds, "Puser"); 
GridViewl .DataSource =ds .Tables [0] .DefaultView; 
GridViewl .DataBind () ; 
Labell2.Text =" Ji " 4GridViewl.PageCount.ToString() +" Ji "; 
int currentpage -GridViewl . PageIndex 4; 
Labelll.Text 下 第" +currentpage.ToString () +" W"; 
Llabel9.Text = 查询 条 件 : Nc" +sqlif +" Vc 符合 条 件 记 录 共 " +ds. Tables [0] . Rows. Count. 

ToString() 条"; 
) 


(5) 明细 /简明 信息 选中 RadioButtonList3_SelectedIndexChanged( ) 事件 


protected void RadioButtonList3 SelectedIndexChanged (object sender, EventArgs e) 
( / [Gridviewl 部 分 信息 可 不 可 见 切换 
if (RadioButtonList3.SelectedIndex =-0) 
{ 
GridViewl.Width =720; 
for (int i-6;i413;i-*4) 
GridViewl .Columns [i] .Visible —false; 
) 
else 
{ 
GridViewl.Width 31200; 
for (int i 4;i 43;i ++ 
GridViewl .Columns [i] -Visible «rue; 
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} 
(6) 保存 用 户 状态 /积分 修改 Button2_Click( ) 事 件 


protected void Button2 Click (object sender,EventArgs e) 
{ 
string vid -TextBox3.Text; 
string stat; 
stat -RadioButtonList4 .SelectedIndex.ToString(); 
if (sqlcon.State --ConnectionState.Closed) sqlcon.Open(); 
if (stat -—"2") stat —"9"; 
SglCommand updae com -new SqlCommand ("update Puser set Pef =" +stat +", Pcount =" + 
TextBox5 .Text +", Ptype 7'" :DropDownList3.Text +"' where ID-'" +vid ?"'",sqlcon); 
updae com.ExecuteNonQuery () ; 
Buttonl Click (sender,e) ; // 刷 新 用 户 列表 
) 


(7) 删除 用 户 Button3. Click( ) 事 件 


protected void Button3 Click (object sender, EventArgs e) 
{ 
string vid -TextBox3.Text; 
SqglCommand delete com -new SqlCommand ("delete from Puser where ID ='" +vid +"'", 
sqlcon); 
if (sqlcon.State --ConnectionState.Closed) sqlcon.Open(); 
delete com.ExecuteNonQuery () ; 
Buttonl Click (sender,e); 
) 


(8) 用 户 类 型 设置 


protected void Button4 Click (object sender, EventArgs e) 
{ 

string newtype -TextBox6.Text; 

if (newtype.Trim().Length =-0) return; 

SqlCammand insert com -new SqlCommand ("insert into Pusertype values ('" tnewtype ?"')", 

sqlcon); 

if (sqlcon.State ==ConnectionState.Closed) sqlcon.Open(); 

try 

{ 
insert com.ExecuteNonQuery () ; 
// 操 作成 功 时 显示 操作 成 功 ,切忌 使 用 respone .write 的 方法 ,以 免 造成 布局 混乱 
Page. ClientScript. RegisterStartupScript (this.GetType (),"", "alert (' 操 作成 功 ! 
');",true); 

} 

catch 

{ 
Page.ClientScript.RegisterStartupScript (this.GetType () , ", "alert ("操作 失败 ,类 
型 可 能 已 存在 ! 7) ;", true); 

} 

update typedrd(); 

Buttonl Click (sender, e) ; 
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protected void Button5 Click (object sender, EventArgs e) 
{ 
string newtype -TextBox6.Text.Trim(); 
if (newtype.Trim().Length ==) return; 
SqlCommand delete com -new SqlCommand ("delete from Pusertype where Ptype = 
('" mewtype +"')", sqlcon) ; 
if (sqlcon.State --ConnectionState.Closed) sqlcon.Open(); 
try 
t 
delete com.ExecuteNonQuery () ; 
Page.ClientScript.RegisterStartupScript (this.GetType () , "", "alert (' 操 作成 
3j! ');", true); 
} 
catch 
{ 
Page. ClientScript.RegisterStartupScript (this.GetType () , "", "alert (' 操 作 失 
败 ,该 类 型 已 被 使 用 ! ') ;",true) ; 
update typedrd(); 
Buttonl Click (sender,e); 


) 
protected void update typedrd() // 当 类 型 更 新 时 ,刷新 相关 的 下 拉 选 项 
{ 
SqlConmand sqlcom new SqlCommand("select * from Pusertype",sqlcon); 
SqlConmand sqlcomBt1 -new SqlCommand ("select * from Btypel",sqlcon); 
SqlConmand sqlcomBt2 -new SqlConmand ("select * from Btype2", sqlcon); 
SqlCommand sqlconBt3 -new SqlCommand ("select * from Btype3", sqlcon); 
SqlDataReader dr; 
SglDataAdapter da new SqlDataAdapter (sqlcom.CommandText , sqlcon) ; 
SglDataAdapter dal new SqlDataAdapter (sqlcomBt1 .CommandText , sqlcon) ; 
SglDataAdapter da2 -new SqlDataAdapter (sqlcomBt2 .CommandText , sqlcon) ; 
SqlDataAdapter da3 -new SqlDataAdapter (sqlcomBt3 .CommandText , sqlcon) ; 
DataSet setting abc -new DataSet () ; 
if (sqlcon.State —-ConnectionState.Closed) sqlcon.Open(); 
dr -sqlcom.ExecuteReader () ; 
DropDownListl.Items.Clear(); 
DropDownList3.Items.Clear(); 
DropDownList4.Items.Clear(); 
DropDownListl . Items .Rdd ("不 限 "); 
DropDownList6.Items.Clear(); 
DropDownList].Items.Clear(); 
DropDownList8 . Items .Clear () ; 
while (dr.Read()) 
i 
DropDownList1 . Items Add (dr ["Ptype"] -ToString () ) ; 
DropDownLi st3. Items .Add (dr ["Ptype"] .ToString()); 
DropDownList4 . Items .Add (dr ["Ptype"] -ToString () ) ; 
} 
dr.Close(); 
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setting abc.Clear () ; 
da.Fill(setting abc, "Pusettype"); 
dal .Fil] (setting abc, "Btypel"); 
da2 .Fill (setting abc, "Btype2" 
da3.Fill (setting abc, "Btype3"); 
Labelll.Text =" 


DropDownListl.SelectedIndex =-1; 

DropDownList3 .SelectedIndex --1; 

DropDownList4 .SelectedIndex =-1; 

DropDownList6.DataSource -setting abc.Tables ["Btypel"].DefaultView; 
ListBoxl.DataSource -DropDownList6 .DataSource; 
DropDownList6.DataTextField -"btype"; 

ListBoxl.DataValueField -"btype"; 

ListBoxl.DataTextField -"btype"; 

DropDownList6.DataValueField -"btype"; 

DropDownLi st7 .DataSource -setting abc.Tables ["Btype2"] . DefaultView; 
DropDownLi st7 .DataTextField -"btype"; 
DropDownList7 .DataValueField -"btype"; 
DropDownLi st8 . DataSource =setting_abc.Tables ["Btype3"] .DefaultView; 
DropDownList8 .DataTextField -"btype"; 
DropDownList8 .DataValueField -"btype"; 
DropDownList9.DataSource -setting abc.Tables["Btypel"].DefaultView; 
DropDownList9.DataTextField -"btype"; 

DropDownList9.DataValueField -"btype"; 

DropDownListl0.DataSource -setting abc.Tables["Btype2"] .DefaultView; 
DropDownList10.DataTextField -"btype"; 

DropDownList10.DataValueField -"btype"; 

DropDownListll.DataSource -setting abc.Tables["Btype3"] .DefaultView; 
DropDownListll.DataTextField -"btype"; 

DropDownListll.DataValueField -"btype"; 

DropDownList6.DataBind|() ; 

DropDownList7.DataBind(); 

DropDownList8 .DataBind () ; 

DropDownList9.DataBind|(); 

DropDownList10.DataBind|(); 

DropDownListll.DataBind(); 

ListBoxl.DataBind(); 

DropDownList6.Items.Add ("不 限 "); 

DropDownList7 . Items .Add ("RBR") ; 

DropDownList8 . Items .Add ("RRR") ; 

DropDownList5 .SelectedIndex =DropDownList5 . Items .Count -1; 
DropDownList6 .SelectedIndex -DropDownList6.Items.Count -1; 
DropDownList7.SelectedIndex =DropDownList7 . Items .Count -1; 
DropDownList8 .SelectedIndex =DropDownList8 . Items .Count -1; 


2. 订单 管理 

包括 订单 查询 ,确认 完 成 (完成 时 执行 用 户 积分 加 减 、 实 存 图 书 数量 减 操作 ) 删除 一 周 
前 新 单 ,界面 如 图 9-12 所 示 。 

(1) 订单 综合 查询 Button14_Click( ) 事 件 
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图 9-12 “订单 管理 "界面 设计 


protected void Button14 Click (object sender, EventArgs e) 


{ 


} 


order sql =" state <10"; 
if (TextBox24.Text.Length ;0) order sql +=" and bid like '%" +TextBox24 .Text +"%' "; 
if (TextBox25.Text.Length >0) order sql +=" and bdt »-'" JTextBox25 .Text +"' "; 
if (TextBox26.Text.Length >0) order sql +=" and bdt «-'" JTextBox26.Text +"' "; 
if (TextBox27.Text.Length;0) order sql +=" and wb like '" +TextBox27 .Text +"'%"; 
if (RadioButtonList8.SelectedIndex S) order sql +=" and state =" + 
RadioButtonList8 .SelectedIndex.ToString|(); 
if (sqlcon.State --ConnectionState.Closed) sqlcon.Open(); 
SglDataAdapter dr ord-new SqlDataAdapter ("select * from order info where " order - 
Sql, sqlcon) ; 
DataSet ds ord-new DataSet () ; 
dr ord.Fill(ds ord,"order info"); 
GridView3.DataSource «ds ord.Tables[0] .DefaultView; 
GridView3 .DataBind(); 


(2) 订单 确认 完成 Cert_Click( ) 事 件 


protected void Cert Click (object sender, EventArgs e) 


{ 


} 


if (GridView3 .SelectedIndex==-1) ( showmessage (" 请 选择 一 个 订单 ") ; return; } 
string bid -GridView3.SelectedRow.Cells[0].Text; 

ord complete (bid) ; 

Button14 Click (sender,e) ; 


/ [RC ord complete (Bid) ,确认 订单 号 为 Bid 的 订单 完成 时 执行 的 操作 
protected void ord complete (string bid) 


{ 


if (bid.Length =-0) return; 

SqlCormand upt =new SqlCommand ("update order info set state -2 where bid -'" +bid +"' and 
state -",sqlcon); 

if (sqlcon.State ==ConnectionState.Closed) sqlcon.Open(); 

try { upt.ExecuteNonQuery () ; } 

catch ( ] 

// 存 书 量 减 少 

SqlCormand upt bn -new SqlCommand ("" , sqlcon) ; 


} 
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upt bn.CommandText -"update binfo set num0 num) -(select bcout from order d b where b. 
bid -binfo.bid and b.id-'" 4bid; 
upt bn.CommandText +="') where binfo.bid in (select bid from order d c where c.id-'" + 
bid +)"; 
upt bn.ExecuteNonQuery () ; 
// 用 户 积分 加 减 
SqlCormand upt pu new SqlCommand ("" , sqlcon) ; 
upt pu.CommandText. ="update Puser set Pcount -Pcount -(select prepay from order info b 
where b.bid-'" tbid; 
upt pu.CommandText +="') *(select floor (tp2) from order info c where c.bid-'" 4bid +" 
') where id-'" 41GridView3.SelectedRow.Cells[1].Text +"'"; 
upt pu.ExecuteNonQuery () ; 


(3) 删除 一 周 前 新 单 
许多 注册 用 户 经 常 下 了 新 订单 以 后 ,长 时 间 置 之 不 理 ,以 致 订单 记录 中 产生 大 量 的 垃圾 
信息 ,系统 设置 管理 员 可 以 将 一 周 前 的 新 订单 视 为 无 效 记录 予以 删除 。 


protected void Button15 Click (object sender, EventArgs e) 


{ 


} 


SqlCormand del ord d new SqlConmand ("", sqlcon); 
SqlCommand del_ord new SqlConmand ("", sqlcon) ; 
string weekbefore -DateTime.Now.AddDays ( -7) .ToString ("d") ; // 一 周 前 日 期 
del ord d.CommandText ="delete from order d where id in (select bid from order info "; 
del ord d.ConmmandText +="where state -0 and bdt «'" weekbefore +"')"; 
del ord.CammandText -"delete from order info where state -0 and bdt <'" 4weekbefore +"'"; 
if(sqlcon.State —--ConnectionState.Closed) sqlcon.Open(); 
SqlTransaction trl -sqlcon.BeginTransaction(); 
del ord d.Transaction r1; 
try 
{ 
del ord d.ExecuteNonQuery (); 
trl.Comit (); 
) 
catch { trl .Rollback(); } 
trl.Dispose(); 
SqlTransaction tr2 -sqlcon.BeginTransaction(); 
del ord.Transaction tr2; 
try 
{ 
del ord.ExecuteNonQuery () ; 
tr2.Comit () 7 
shownessage ("操作 成 功 ") ; 
) 
catch ( tr2.Rollback(); shownessage ("操作 失败 "); } 
Buttonl4 Click (sender,e) ; 


3. 书籍 管理 
包括 综合 查询 三 级 分 类 设置 ,新 增 修改. 上 传 书 封 文件 等 功能 ,界面 如 图 9-13 所 示 。 
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图 9-13 “书籍 管理 "界面 设计 


(1) 图 书 查 询 Button6_Click( ) 事 件 


protected void Button6 Click (object sender, EventArgs e) 
{ 
DataSet ds new DataSet () ; 
string dtl,dt2,ddt; 
dt1 ="2000 -01 -01"; 
dt2 22010 -12 31"; 
ddt -TextBoxll.Text.Trim(); 
// 条 件 判断 
sglbinfo -"bid»'0'"; 
if (TextBox7.Text.Trim().length >0) sqlbinfo +=" and Bid like '$" + 
TextBox7.Text.Trim() 4"$'"; 
if (TextBox8.Text.Trim().Length?0) sqlbinfo +=" and Bname like '$" + 
TextBox8 .Text .Trim() "$'"; 
if (TextBox9 .Text.Trim() .Length >0) sqlbinfo +=" and Bauth like '$" 十 
TextBox9.Text.Trim() +"%'"; 
if (TextBox10.Text.Trim().Length 20) sqlbinfo +=" and Bpub like '$" + 
TextBox10.Text.Trim() +" 


if (TextBox1l.Text.Trim().Length 0) 
{ 

dtl -ddt.Substring (0,4) +" -01 -01"; 

dt2 -ddt .Substring (5,4) +" -12 -31"; 

sqlbinfo +=" and bpdt >="" 4dt1 4"' and bpdt <="" 4dt2 +"'"; 
) 


if (DropDownList6.Text! = 不 限 " ) sqlbinfo +=" and bt1 -'" 4DropDownList6.Text +"'"; 


if (DropDownList].Text! 


if (DropDownList8 .Text! 
if (DropDownList8 .Text! 


= 不 限 ") sqlbinfo +=" and bt2 ='" 4DropDownList7 . Text +" 


A") sqlbinfo +=" and bt3 ='" 4DropDownList8 .Text 4"'"; 
A") sqlbinfo +=" and bt3 ='" 4DropDownList8 .Text 4"'"; 


if (RadicButtonList7.Text! 二 不 限 ") sqlbinfo +=" and Bnew =" + 
RadioButtonList].SelectedIndex.ToString(); 


switch (DropDownList5.SelectedIndex) 
f 


} 
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case 0: 
sqlbinfo +=" and num0 -numl Q"; 
break; 
case 1: 
sqlbinfo +=" and num0 -numl -0"; 
break; 
case 2: 
sqlbinfo +=" and num0 -numl >0 and num0 numl «-9"; 
break; 
case 3: 
sqlbinfo +=" and num -numl >=10 and num0 -num «-19"; 
break; 
case 4: 
sqlbinfo +=" and num0 -numl > 之 0 and num -numl <49"; 
break; 
case 5: 
sqlbinfo +=" and num0 -numl »-50 and num0 -numl «-99"; 
break; 
case 6: 
sqlbinfo +=" and num0 -numl >99"; 
break; 


) 

SqlDataAdapter da -new SqlDataAdapter ( "select * from Binfo where " 4sqlbinfo, sqlcon); 
if (sqlcon.State —-ConnectionState.Closed) sqlcon.Open(); 

da.Fill (ds, "Binfo"); 

GridView2 .DataSource =ds .Tables [0] .DefaultView; 

GridView2 .DataBind () ; 

update typedrd(); 

Labe129.Text =" Jt " 4GridView2 .PageCount .ToString() +" W"; 

Label30.Text =" 第 "+(GridView2 .PageIndex +1) .ToString() +" Ji"; 


protected void update typedrd() 


{ 


// 三 级 分 类 刷新 函数 , 当 类 型 更 新 时 ,刷新 相关 的 下 拉 选 项 


SqlCormand sqlcom =new SqlConmand ("select * from Pusertype", sqlcon); 
SqlCormand sqlcomBt1 -new SqlCommand("select * from Btypel",sqlcon); 
SqlCommand sqlcomBt2 new SqlCommand ("select * from Btype2",sqlcon); 
SqlCommand sqlcomBt3 -new SqlCommand ("select * from Btype3",sqlcon); 
SqlDataReader dr; 

SqlDataAdapter da new SqlDataAdapter (sqlcom.CommandText, sqlcon) ; 
SqlDataAdapter dal -new SqlDataAdapter (sqlcomBt1 .CommandText , sqlcon) ; 
SqlDataAdapter da2 -new SqlDataAdapter (sqlcomBt2 . CommandText , sqlcon) ; 
SqlDataAdapter da3 -new SqlDataAdapter (sqlcomBt3 .CommandText , sqlcon) ; 
DataSet setting abc -new DataSet () ; 

if (sglcon.State --ConnectionState.Closed) sqlcon.Open(); 

dr -sqlcom.ExecuteReader () ; 

DropDownListl.Items.Clear(); 

DropDownList3.Items.Clear(); 

DropDownList4.Items.Clear(); 

DropDownLá st . Items . Add ("WBR") ; 

DropDownList6.Items.Clear(); 
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DropDownList].Items.Clear(); 
DropDownList8.Items.Clear(); 


while (dr.Read()) 

{ 
DropDownList1 . Items .Add (dr ["Ptype"] .ToString()); 
DropDownList3 . Items .Add (dr ["Ptype"] .ToString ()); 
DropDownList4 . Items .Add (dr ["Ptype"] .ToString()); 

} 

dr.Close(); 


setting abc.Clear(); 
da.Fill(setting abc, "Pusettype 
dal .Fill (setting abc, "Btypel"); 

da2 .Fill (setting abc, "Btype2") ; 

da3.Fill(setting abc, "Btype3"); 

Labelll.Text =""; 

Labell2.Text =""; 

DropDownListl.SelectedIndex =-1; 

DropDownList3.SelectedIndex =-1; 

DropDownList4.SelectedIndex =-1; 

DropDownList6.DataSource -setting abc.Tables["Btypel"].DefaultView; 
ListBoxl.DataSource -DropDownList6.DataSource; 
DropDownList6.DataTextField -"btype"; 

ListBoxl.DataValueField -"btype"; 

ListBoxl.DataTextField ="btype"; 

DropDownList6.DataValueField -"btype"; 

DropDownList?7.DataSource -setting abc.Tables["Btype2"] .DefaultView; 
DropDownList].DataTextField -"btype"; 

DropDownList7.DataValueField -"btype"; 

DropDownList8 .DataSource -setting abc.Tables["Btype3"] .DefaultView; 
DropDownList .DataTextField ="btype"; 

DropDownList8 .DataValueField -"btype"; 

DropDownList9.DataSource -setting abc.Tables["Btypel"].DefaultView; 
DropDownList9.DataTextField -"btype"; 

DropDownList9.DataValueField -"btype"; 

DropDownList10.DataSource -setting abc.Tables|["Btype2"] .DefaultView; 
DropDownListl0.DataTextField -"btype"; 
DropDownListl0.DataValueField -"btype"; 

DropDownListll.DataSource -setting abc.Tables ["Btype3"] .DefaultView; 
DropDownListll.DataTextField -"btype"; 
DropDownListll.DataValueField -"btype"; 

DropDownList6.DataBind(); 

DropDownList].DataBind(); 

DropDownList8 .DataBind(); 

DropDownList9.DataBind(); 

DropDownListl0 .DataBind(); 

DropDownListll.DataBind(); 

ListBoxl.DataBind(); 

DropDownList6.Ttems.Add (" 不 限 "); 

DropDownList? . Items . Add ("不 限 "); 
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DropDownList8 . Items . Add ("不 限 "); 

DropDownList5 .SelectedIndex -DropDownList5.Items.Count -1; 
DropDownList6 .SelectedIndex =DropDownList6 .Items .Count -1; 
DropDownList7 .SelectedIndex =DropDownList7 .Items .Count -1; 
DropDownList8 .SelectedIndex =DropDownList8 .Items .Count 1; 


} 
(2) 三 级 分 类 : 增加 Button12_Click( ) 事 件 


protected void Button12 Click (object sender, EventArgs e) 
{ 
if (TextBox23.Text.Trim() .Length --0) return; 
string tbname —"Btypel"; 
ListBoxl.Items.Clear(); 
switch (Menu2.SelectedValue) 
{ 
case "一 级 分 类 ": 
f 
tbname -"Btypel"; 
break; 
} 
case "二 级 分 类 ": 
{ 
tbname ="Btype2"; 
break; 
} 
case "三 级 分 类 ": 
f 
tbname ="Btype3"; 
break; 


} 
if (sqlcon.State ==ConnectionState.Closed) sqlcon.Open(); 
SqlDataAdapter da -new SqlDataAdapter ("select * from "+tbname, sqlcon); 
SqlCommandBuilder cmdbld -new SqlConmandBui lder (da) ; 
DataSet ds new DataSet () ; 
da.Fill(ds, tbname); 
DataTable dtb -ds.Tables [0]; 
DataRow drow -dtb.NewRow () ; 
drow[0] -TextBox23.Text; 
dtb.Rows.Add (drow) ; 
da.Update (dtb) ; 
ListBoxl.DataSource =ds . Tables [0] .DefaultView; 
ListBoxl.DataBind(); 

) 


(3) 三 级 分 类 : 删除 Button13, Click ( ) 事 件 


protected void Button13 Click (object sender, EventArgs e) 
{ 
if (TextBox23 .Text.Trim() .Length ==) return; 
string tbname -"Btypel"; 
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) 


ListBoxl.Items.Clear(); 
switch (Menu2.SelectedValue) 
{ 
case "一 级 分 类 ": 
{ 
tbname -"Btypel"; 
break; 
) 
case "二 级 分 类 ": 
{ 
tbname -"Btype2"; 
break; 
} 
case "二 级 分 类 ": 
{ 
tbname -"Btype3"; 
break; 


) 

if (sqlcon.State --ConnectionState.Closed) sqlcon.Open(); 
SqlDataAdapter da -new SqlDataAdapter ("select * from " *tbname +" where Btype -'" + 
TextBox23.Text +"'", sqlcon); 

SqlCormandBujilder cmdbld -new SqlCommandBuilder (da) ; 
DataSet ds -new DataSet () ; 

da.Fill(ds,tbname); 

DataTable dtb =ds .Tables [0]; 

DataRow drow =dtb.Rows [0] ; 

drow.Delete(); 

da. Update (dtb) ; 

ListBoxl.DataSource =ds .Tables [0] .DefaultView; 
ListBoxl.DataBind(); 


(4) 新 增 图 书 Button. Click ( ) 事 件 


protected void Button8 Click (object sender, EventArgs e) 


{ 


TextBox12 .Enabled true; 
TextBox12 .Text =""; 
DropDownList9.SelectedIndex =-1; 
DropDownList10 .SelectedIndex =-1; 
DropDownListll.SelectedIndex =-1; 
TextBox13 .Text =""; 
TextBoxl4.Text —""; 
TextBoxl6.Text =""; 

TextBox17 .Text —""; 

TextBox20 .Text ="0"; 

TextBox21 .Text -"1"; 

TextBox18 .Text —"0"; 
TextBox19.Text —"0"; 

TextBox22 .Text =""; 


} 
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RadioButtonList6.SelectedIndex -0; 
ins edt =; 


(5) 保存 ( 增 \ 改 )Button9_Click( ) 事 件 


protected void Button9 Click (object sender, EventArgs e) 


{ 


SqlDataAdapter da -new SqlDataAdapter ("select * from binfo where bid ='" +TextBox12. 


Text +"'" ,sqlcon); 
if (sqlcon.State ==ConnectionState.Closed) sqlcon.Open(); 
SqlCommandBuilder cmd -new SqlCommandBui lder (da) ; 
DataSet ds -new DataSet () ; 
da.Fill(ds, "binfo"); 
DataTable dt -ds Tables ["binfo"]; 
if (ins edt ==) 
{ 
DataRow trow -dt.Rows [0]; 
trow["bt1"] -DropDownList9.Text; 
trow["bt2"] -DropDownListl0 .Text; 
trow["bt3"] -DropDownListll.Text; 
trow["bname"] -TextBox13.Text; 
trow["bpub"] -TextBoxl4 Text; 
trow["bauth"] =TextBox16 .Text; 
trow["bpdt"] -DateTime.Parse (TextBox17 . Text) ; 
trow["bpri"] =float.Parse (TextBox20.Text); 
trow["bf"] —£loat.Parse (TextBox21 . Text) ; 
trow["num0"] =Int32 .Parse (TextBox18 . Text.) ; 
trow["numl"] -Int32 . Parse (TextBox19.Text) ; 
trow["Bnew"] -RadioButtonList6.SelectedIndex; 


da. Update (dt) ; 


{ Page.ClientScript.RegisterStartupScript (this.GetType () , "", "alert (' 保 存 记 


录 成 功 !'); ", true); } 
} 
catch 
{ Page.ClientScript.RegisterStartupScript (this.GetType () , 
'); ",true); } 
) 
if (ins edt ==) 
{ 
DataRow trow -dt.NewRow (); 
trow["bid"] -TextBox12.Text; 
trow["bt1"] -DropDownList9.Text; 
trow|["bt2"] -DropDownListl0.Text; 
trow["bt3"] -DropDownListll.Text; 
trow["bname"] -TextBox13.Text; 
trow["bpub"] -TextBoxl4.Text; 
trow["bauth"] -TextBox16.Text; 
trow|["bpdt"] -DateTime.Parse (TextBox17 Text) ; 


m, "alert ("操作 失败 ! 
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trow|["bpri"] =float . Parse (TextBox20 .Text) ; 
trow["bf"] =float .Parse (TextBox21 . Text) ; 
trow["num0"] =Int32 . Parse (TextBox18 . Text) ; 
trow["num] "] -Int32.Parse (TextBox19.Text) ; 
trow["Bnew"] -PadioButtonList6.SelectedIndex; 
dt.Rows .Add (trow) ; 
try 
t 
da Update (dt) ; 
{ Page.ClientScript.RegisterStartupScript (this.GetType () , "", "alert (' 保 存 记 
SRI 1"); ", trae); } 
} 
catch 
{ Page.ClientScript.RegisterStartupScript (this.GetType () , ", "alert (' 操 作 失 败 ! 
'); ",true); } 
} 
Button6 Click (sender,e); 
} 


(6) 删除 Button10_Click( ) 事 件 


protected void Buttonl0 Click (object sender, EventArgs e) 
{ 
SqlConmand cmd =new SqlConmand ("delete from binfo where bid -'" +T extBox12.Text +"'", 
Sqlcon); 
if (sqlcon.State —-ConnectionState.Closed) sqlcon.Open(); 
cnd.ExecuteNonQuery () ; 
Button6 Click (sender,e); 
) 


(7) 上 传 文件 Button11_Click( ) 事 件 


protected void Buttonll Click (object sender, EventArgs e) 
$ 
if (FileUploadl .FileName.Trim() .Length =-0) return; 
if (TextBox12.Text.Trim() .Length ==) 
FileUploadl.SaveAs (Server .MapPath (" ~/image/book/") +FileUpload1 .FileName) ; 
else 
FileUploadl.SaveAs (Server. MapPath (" ~/image/book/") *TextBox12. Text. Trim () + 
"jpg"; 
) 


(8) GridView2 选择 记录 事件 


protected void GridView2 SelectedIndexChanged (object sender, EventArgs e) 
t 
string bid -GridView2 .SelectedDataKey.Value.ToString|(); 
SqlDataAdapter da -new SqglDataAdapter ("select + from Binfo where bid -'" +bid 可 
sqlcon); 
DataSet ds -new DataSet (); 
if (sqlcon.State --ConnectionState.Closed) sqlcon.Open(); 
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ds.Tables.Clear (); 

da.Fill (ds, "binfo"); 

DataTable tbl -new DataTable () ; 

tbl -ds.Tables ["binfo"]; 

DataRow trow -tbl.Rows [0]; 

TextBox12 .Text -trow [0] .ToString(); 

DropDownList9.Text —trow[1].ToString(); 
DropDownList10.Text -trow[2] .ToString(); 
DropDownListll.Text =trow [3] .ToString () ; 

TextBox13 .Text =trow[4] -ToString () ; 

TextBox14 .Text =trow[6] .ToString () ; 

TextBox16 .Text =trow[5] .ToString () ; 

TextBox17 .Text =( (DateTime) (trow[7]) ) .ToShortDateString(); 
TextBox20 .Text «row [8] .ToString (); 

TextBox21 .Text =trow [9] .ToString(); 

TextBox18 .Text =trow[14] .ToString () ; 

TextBox19.Text —trow[15] .ToString(); 

TextBox22 .Text -trow [13] .ToString (); 

if (trow[10] .ToString () .Length —-0) RadioButtonList6.SelectedIndex -0; 
else RadioButtonList6.SelectedIndex -Int32.Parse (trow [10] . ToString ()); 
Tmage2 . ImageUr1 =" ^/image/book/" tbid.Trim() *".jpg"; 

ins edt-0; 

) 

小 结 : 

本 章 通过 介绍 一 个 Web 项 目的 设计 和 实现 过 程 ,使 学 生 对 动态 网 站 应 用 项 目的 开 
发 过 程 获得 整体 的 认识 ,能 帮助 学 生 熟 练 掌握 各 种 控件 的 使 用 方法 ,提高 学 生 的 编程 
能 力 。 

该 项 目 除 了 一 般 的 ASP. NET 应 用 技术 运用 外 ,重点 要 解决 以 下 几 个 方面 的 技术 。 

(1) 页 面 公用 变量 传递 。 

(2) 页 面 事务 控制 。 

(3) 图 形 验证 技术 。 

(4) 记录 的 加 解密 技术 。 


思考 与 练习 


1. 开发 一 个 论坛 的 网 站 。 

WR: 

(1) 对 讨论 话题 进行 分 类 ,在 主页 中 列 出 各 分 类 的 热门 话题 。 

(2) 用 户 分 类 控制 ,系统 应 考虑 3 类 用 户 的 不 同 权限 。 

G) 话题 跟 帖 分 级 展开 ,发帖 和 跟 帖 者 可 以 修改 和 删除 自发 帖 。 

(4) 后 台 管理 模块 包括 “用 户 管理 "“ 帖 管理 "和 “系统 设置 "功能 。 

(5) 设计 界面 应 清晰 美观 ,功能 导向 性 强 ,操作 简单 。 

2. 利用 C# 语 言 编写 一 个 字符 串 加 解密 的 动态 库 , 并 在 页 面 中 调用 ,加 密 规 则 自行 


= 
定义 。 


思考 与 练习 答案 


第 工 章 
一 、 填空 题 
l. 解释 型 ,编译 型 
2. Microsoft,. NET Framework , Microsoft Visual Studio . NET 集成 开发 环境 
3. 具有 交互 性 的 ,asp、jsp、.php、aspx 


二 、 简 答题 

1. 答 : 虚拟 目录 相当 于 物理 目录 在 Web 服务 器 上 的 别名 , 它 不 仅 使 用 户 避 免 了 宛 长 的 
URL ,而 且 是 一 种 很 好 的 安全 措施 ,因为 虚拟 目录 对 所 有 浏览 者 隐藏 了 物理 目录 结构 。 

2. Wt 


$2 


2. 101,101 

3. 

4. 创建 对 象 ,释放 对 象 
5. 异常 

二 、 编程 题 

1. class Program 


{ 
static void Main (string[]args) 
{ 
double[]a new double [10] ; 
System.Console.WriteLine ("请 输入 10 Cz) ; 
inti; 
double max,min; 
for (i;i 40;i ++ 
a[i] =double . Parse (System.Console .ReadLine () ) ; 
max =a [0]; 
min=a[0]; 
for (i;i 40;i ++} 
{ 
if (a[i] >max) max-a[i]; 
if (a[i] in) min-a[il; 
} 
System.Console.WriteLine ("最 大 数 为 :" max +", 最 小 数 为 :" min) ; 
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System.Console.Read() ; 


} 


2. class Program 


{ 

static void Main (string[]args) 

{ 
String str-""; 
int x; 
for (x31949;x «-2010;x ++) 

if (x$4 =Æ && x $100! © [Ix$400 =æ) str +=x +"; 

System.Console.WriteLine ("1949 年 到 2010 年 的 闵 年 有 : \n" +str) ; 
System.Console.Read() ; 


} 
3. class Car 


{ 
string Color, Name, ProductPlace; 
public Car (string a, string b, string c) 


Color =a; 
Name =b; 
ProductPlace =; 


void Run () 


System. Console. WriteLine ("我 是 "+Name 要 车 ,颜色 是 " +Color +", j^ Jb fE" + 
ProductPlace); 


static void Main (string[]args) 


Car car new Car ("VR fa", "大 众 ", "上海 "); 
car.Run(); 
System.Console.Read() ; 
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一 、 填 空 题 
l. .aspx,. cs 
2. HTML 控件 , Web 控件 ,验证 控件 ,用 户 控件 
3. GroupName 
4. AutoPostBack 
5. RequiredFieldValidator , RangeValidator 


思考 与 练习 答案 


6. XML 
7. [1-9][0-9]14,] 
二 、 编 程 题 
略 
第 4 章 
一 、 填空 题 
l. 所 有 浏览 器 均 共享 的 ;从 启动 Web 服务 器 开始 ,直到 关闭 Web 服务 器 时 停止 
2. 浏览 器 独 享 的 ;从 浏览 器 访问 服务 器 的 第 一 个 网 页 开始 ,直到 关闭 浏览 器 或 会 话 过 
WAE 
3. Init, Load 
4. Get, Post, Post 
5. 20,90 
二 、 简 答题 
略 
$5 
一 、 填 空 题 
1. DataSet, Connection ,Command , DataReader , DataAdapter 
2. 数据 命令 ,数据 库 连接 ,填充 DataSet, 更 新 数据 库 ,DataSet 
3. Command 对 象 ,DataAdapter 对 象 
4. SelectCommand , CommandBuilder 
二 、 简 答题 
略 
第 6 章 
一 、 填空 题 
1. 表格 ,分 页 ,排序 ,筛选 
2. 会 自动 调用 本 页 所 有 控件 的 DataBind( ) 方 法 
3. 编辑 , 绑 定 ,模板 
4. OnltemCommand 
二 、 简 答题 
略 
第 7 章 
一 、 填空 题 
1. using System. IO ; 
2. 字符 , 读 取 ,字符 , 写 入 , 字 节 
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3. 输入 ,输出 
二 、 简 答题 
Wi 
48 8 
— HH 
. Machine. config, Web. config 
. Web. config, Global. asax , System. Web. HttpApplication 
. 皮肤 文件 (. skin) ,级 联 样式 表 (. ess) ,图 表 文 件 
. 元 素 ,类 名 ,ID 名 
. 皮肤 文件 ,本 地 页 
. 本 地 页 ,皮肤 文件 
= EH 
略 
第 9 5t 
略 


ON tn ROC 2 一 
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